项目作者: wong2

项目描述 :
create curses based interactive selection list in the terminal
高级语言: Python
项目地址: git://github.com/wong2/pick.git
创建时间: 2016-01-17T04:28:49Z
项目社区:https://github.com/wong2/pick

开源协议:MIT License

下载


pick

image
PyPI
PyPI

pick is a small python library to help you create curses based
interactive selection list in the terminal.

Basic Multiselect

Installation

  1. $ pip install pick

Usage

pick comes with a simple api:

  1. >>> from pick import pick
  2. >>> title = 'Please choose your favorite programming language: '
  3. >>> options = ['Java', 'JavaScript', 'Python', 'PHP', 'C++', 'Erlang', 'Haskell']
  4. >>> option, index = pick(options, title)
  5. >>> print(option)
  6. >>> print(index)

outputs:

  1. >>> C++
  2. >>> 4

pick multiselect example:

  1. >>> from pick import pick
  2. >>> title = 'Please choose your favorite programming language (press SPACE to mark, ENTER to continue): '
  3. >>> options = ['Java', 'JavaScript', 'Python', 'PHP', 'C++', 'Erlang', 'Haskell']
  4. >>> selected = pick(options, title, multiselect=True, min_selection_count=1)
  5. >>> print(selected)

outputs:

  1. >>> [('Java', 0), ('C++', 4)]

Options

  • options: a list of options to choose from
  • title: (optional) a title above options list
  • indicator: (optional) custom the selection indicator, defaults to *
  • default_index: (optional) set this if the default selected option
    is not the first one
  • multiselect: (optional), if set to True its possible to select
    multiple items by hitting SPACE
  • min_selection_count: (optional) for multi select feature to
    dictate a minimum of selected items before continuing
  • screen: (optional), if you are using pick within an existing curses application set this to your existing screen object. It is assumed this has initialised in the standard way (e.g. via curses.wrapper(), or curses.noecho(); curses.cbreak(); screen.kepad(True))
  • position: (optional), if you are using pick within an existing curses application use this to set the first position to write to. e.g., position=pick.Position(y=1, x=1)
  • quit_keys: (optional), if you want to quit early, you can pass a key codes.
    If the corresponding key are pressed, it will quit the menu.

Community Projects

pickpack: A fork of pick to select tree data.