Skip to main content

Kind of like a non intrusive addon for the standard input()

Project description

InputPowertools

Eliminate the annoyances of getting input or building a cli in python!

Prolog

I love using command line interfaces and I think most people like building these small tools as well, but its really annoying to have to build the interface between the user and your program, hence I build this python package to take care of this part for you.

Installation

$ pip install InputPowertools

Examples

input()

Alpha

>>> print(f"Result: {input('Type your name:', Mode.ALPHA)}")

Type your name:  >? 123
🛑 Please enter a value that is completely alphabetic (no punctuation, numbers, emojis or nothing)...
Type your name:  >? Malte
Result: Malte

Numeric

>>> print(f"Result: {input('How old are you:', Mode.NUMERIC, domain=lambda x: x % 1 == 0)}")

How old are you:  >? 😀
🛑 Please enter a number...
How old are you:  >? 13.5
🛑 Please enter a value that fits the answers domain...
How old are you:  >? 16
Result: 16

Options

>>> print(f"Result: {input('Are you a what kind of person are you?', Mode.OPTIONS, options=['Cat person', 'Dog person', 'Bird person'])}")

Are you a what kind of person are you? 
1 -> Cat person
2 -> Dog person
3 -> Bird person
Select option [1-3]:  >? Though question
🛑 Please enter a number...
Select option [1-3]:  >? 0
🛑 Please enter a value that fits the answers domain...
Select option [1-3]:  >? 4
🛑 Please enter a value that fits the answers domain...
Select option [1-3]:  >? 2
Result: (1, 'Dog person')

Regex

>>> print(f"Result: {input('What is your favorite hex color?', Mode.REGEX, regex=r'(#([a-fA-F0-9]{6}|[a-fA-F0-9]{3}))', regex_description='Hexadecimal Color. Something like #123 or #FF32CD')}")

What is your favorite hex color?  >? red
🛑 Please enter a value that fits this description: Hexadecimal Color. Something like #123 or #FF32CD
What is your favorite hex color?  >? #F00
Result: #F00

Defaults

Just pressing enter

>>> print(f"Result: {input('Type your name:', Mode.ALPHA, default='Hannes')}")

Type your name: (Hannes) >? 
Result: Hannes

Typing something else

>>> print(f"Result: {input('Type your name:', Mode.ALPHA, default='Hannes')}")

Type your name: (Hannes) >? Malte
Result: Malte

Confirm

>>> print(f"Result: {input('Type your name:', Mode.ALPHA, confrim=True)}")

Type your name:  >? Malte
Do you want to select "Malte"? 
1 -> yes
2 -> no
Select option [1-2]: (2) >? 1
Result: Malte

CLI

Guide

$  python examples/example\ 1.py

For more information: examples/example 1.py --help

Analysing the docstring and type hints to generate --help

$  python examples/example\ 1.py --help

Some function
  A function that is truly amazing... wow!
Return: Some fascinating thing
        Options:
                --help
                        Prints out information about the program.
                         Type:    bool
                         Default: False
                --a
                        Is a variable called a
                --b
                        Is a variable called b
                         Type:    str
                --c
                        Is a variable called c
                         Type:    list
                --d
                        Is a variable called d
                         Type:    bool
                         Default: False

Analysing the function parameters to generate cli

$ python examples/example\ 1.py  --a lol --b "this is a value with spaces" --c 4 2 "test123" --d

a='lol' b='this is a value with spaces' c=[4, 2, 'test123'] d=True

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

inputpowertools-1.0.2.tar.gz (9.7 kB view details)

Uploaded Source

Built Distribution

inputpowertools-1.0.2-py3-none-any.whl (6.6 kB view details)

Uploaded Python 3

File details

Details for the file inputpowertools-1.0.2.tar.gz.

File metadata

  • Download URL: inputpowertools-1.0.2.tar.gz
  • Upload date:
  • Size: 9.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.3

File hashes

Hashes for inputpowertools-1.0.2.tar.gz
Algorithm Hash digest
SHA256 319dce0e2bdda7438845d24503311f024049db0240abac8f7ac6c349e1403610
MD5 01e6111002dcd888389d2a65838ce4da
BLAKE2b-256 e463ff645829645e7454a38dc63ebe1201a966ebc5b3a2b6509a73b1944123a5

See more details on using hashes here.

File details

Details for the file inputpowertools-1.0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for inputpowertools-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 4646ec716fd00a27ffa73dd1acbf2d555bcd3481aef0aec781c05b7e93f901c8
MD5 f580600d229907b3c4e4d9c086637213
BLAKE2b-256 33ddc57eac2c9d486b82247be14b419add12bf735862cd44929d2245f8a40c23

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page