Skip to main content

A powerful one line solution for collecting CLI user input with absolutely zero boilerplate

Project description

PyMagicPrompt

A powerful one line solution for CLI user input with absolutely zero boilerplate.

Features

  • Full lifecycle abstraction, by default looping until valid input

  • Automatic terminal cleanup for subsequent prompts/answers

  • Type inference & casting for answer submissions

  • Customizable boolean conversion for common English words

  • Built in common validators

  • Support for custom validation functions

  • Fully customizable prompt formatting & colors

  • Customizable answer sanitization & formatting

  • Obscured text for password inputs

  • Options can be specified by both kwargs and options dict

By default, prompt() will work out of the box for most use cases with zero customization.


Example Usage

Basic prompt

name = prompt("What is your name")
# > What is your name: John
print(name)  # 'John'

Usage of built in validators

age = prompt("Enter your age", numOnly=True)
# > Enter your age: 25
print(age)  # 25 (int)

Custom validators

def validate_range(x): 
    return 1 <= int(x) <= 10

num = prompt("Enter number 1-10", validators=[validate_range])
# > Enter number 1-10: 5
print(num)  # 5 (int)

Common options for multiple inputs

base = {
    "alphaOnly": True,  # Only allow letters
    "capAnswer": True,  # Capitalize the answer
    "color": "green",  # Use green color for prompt
    "suffixStr": " >> ",  # Custom suffix
    "caratStr": "! ",  # Custom carat
}

firstName = prompt("First name", options=base)
# ! First Name >> john
print(f"First name: {firstName}")  # First name: John

lastName = prompt("Last name", options=base)
# ! Last Name >> smith
print(f"Last name: {lastName}")  # Last name: Smith

Custom boolean conversion

proceed = prompt("Continue?", trueStrs=["sure", "ok", "yes"])
# > Continue?: ok
print(proceed)  # True (bool)

Parameters

Parameter Type Default Description
prompt str required The prompt text to display to the user
options PromptOptions | None None Dictionary of options that can override default parameters
loop bool True Keep prompting until valid input is received
capPrompt bool True Capitalize the first letter of the prompt
titlePrompt bool True Convert prompt to title case
carat bool True Add a carat prefix to the prompt
caratStr str "> " String to use as carat
suffix bool True Add a suffix to the prompt
suffixStr str ": " String to use as suffix
capAnswer bool False Capitalize the first letter of string answers
titleAnswer bool False Convert string answers to title case
alphaOnly bool False Only accept alphabetic input
numOnly bool False Only accept numeric input
alphaNumOnly bool False Only accept alphanumeric input
floatOnly bool False Only accept floating-point numbers
notEmpty bool True Reject empty input
castAnswer bool True Attempt to cast the answer to an appropriate type
color str "" Color name for the prompt (black, red, green, yellow, blue, magenta, cyan, white)
isPassword bool False Mask input characters
clearAfterResponse bool False Clear the prompt after receiving valid input
trueStrs tuple[str, ...] ("true", "yes", "y") Strings to interpret as True
falseStrs tuple[str, ...] ("false", "no", "n") Strings to interpret as False
pwFailMsg str "Invalid password" Message to display on invalid password input
validators list [] List of custom validation functions

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

magicprompt-0.2.4.tar.gz (7.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

magicprompt-0.2.4-py3-none-any.whl (8.8 kB view details)

Uploaded Python 3

File details

Details for the file magicprompt-0.2.4.tar.gz.

File metadata

  • Download URL: magicprompt-0.2.4.tar.gz
  • Upload date:
  • Size: 7.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.2

File hashes

Hashes for magicprompt-0.2.4.tar.gz
Algorithm Hash digest
SHA256 92e629cdecdd939fe9de7c7dc9f66e308e29692e8718c0131ca6dae1feb576bc
MD5 2b1b31c01e95de890b99ee2524546a4c
BLAKE2b-256 24777ac8397da500626391cf6caa49267896a201f5ab42f90e1bfd33d89a6c5f

See more details on using hashes here.

File details

Details for the file magicprompt-0.2.4-py3-none-any.whl.

File metadata

  • Download URL: magicprompt-0.2.4-py3-none-any.whl
  • Upload date:
  • Size: 8.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.2

File hashes

Hashes for magicprompt-0.2.4-py3-none-any.whl
Algorithm Hash digest
SHA256 4e55471e646c68a70dd0561aa425ac2f6988e92b39b2b9884cb0ef9032026cf6
MD5 0309037a61f0fc04905fe5891d803b7b
BLAKE2b-256 682cda312c545152c6b6936993a5d3a850a96ed1ec43cb30b73eb61e7b2b2d22

See more details on using hashes here.

Supported by

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