Skip to main content

Query a user for input with a timeout.

Project description

Description

A tiny, simplistic little alternative to the standard Python input()-function allowing you to specify an optional timeout for the function.

pytimedinput should work on both Windows and Linux, though no exceedingly extensive testing has been done and there might be bugs.

Install

$ pip3 install pytimedinput

Usage

timedInput()

timedInput() works similar to Python’s default input() - function, asking user for a string of text, but timedInput() allows you to define an amount of time the user has to enter any text or how many consecutive seconds to wait for input, if the user goes idle.

def timedInput(prompt="", timeout=5, resetOnInput=True, maxLength=0, allowCharacters="", endCharacters="\x1b\n\r")

The function timedInput() from pytimedinput accepts the following parameters:

  • prompt, str: a string to show the user as a prompt when waiting for input.

    Defaults to an empty string.

  • timeout, int: how many seconds to wait before timing out.

    Defaults to 5 seconds, use -1 to disable.

  • resetOnInput, bool: Reset the timeout-timer any time user presses a key.

    Defaults to True.

  • maxLength, int: the maximum length of the string user is allowed to enter.

    Defaults to 0, ie. unlimited.

  • allowCharacters, str: Which characters the user is allowed to enter.

    Defaults to “”, ie. any character.

  • endCharacters, str: On which characters to stop accepting input.

    Defaults to “\x1b\n\r”, ie. ESC, newline and carriage-return. Cannot be empty.

The function returns a tuple of:

  • str: a string containing whatever the user typed, regardless of whether the function timed out or not.

  • bool: whether the function timed out or not.

Example:

from pytimedinput import timedInput
userText, timedOut = timedInput("Please, do enter something: ")
if(timedOut):
    print("Timed out when waiting for input.")
    print(f"User-input so far: '{userText}'")
else:
    print(f"User-input: '{userText}'")

timedKey()

timedKey() waits for the user to press one of a set of predefined keys, with a timeout, while ignoring any keys not on the list.

def timedKey(prompt="", timeout=5, resetOnInput=True, allowCharacters="")

The function timedKey() from pytimedinput accepts the following parameters:

  • prompt, str: a string to show the user as a prompt when waiting for input.

    Defaults to an empty string.

  • timeout, int: how many seconds to wait before timing out.

    Defaults to 5 seconds, use -1 to disable.

  • resetOnInput, bool: Reset the timeout-timer any time user presses a key.

    Defaults to True.

  • allowCharacters, str: Which characters the user is allowed to enter.

    Defaults to “”, ie. any character.

The function returns a tuple of:

  • str: a string containing the key the user pressed or an empty string.

  • bool: whether the function timed out or not.

Example:

from pytimedinput import timedKey
userText, timedOut = timedKey("Please, press 'y' to accept or 'n' to decline: ", allowCharacters="yn")
if(timedOut):
    print("Timed out when waiting for input. Pester the user later.")
else:
    if(userText == "y"):
        print("User consented to selling their first-born child!")
    else:
        print("User unfortunately declined to sell their first-born child!")

Tip: use timedKey() for the infamous “Press any key to continue.”-prompt!

from pytimedinput import timedKey
timedKey("Press any key to continue.", timeout=-1)

timedInteger() and timedFloat()

timedInteger() and timedFloat work like timedInput(), except they only allow the user to enter numbers, and comma or period in case of timedFloat. Can be used to enter a negative number.

def timedInteger(prompt="", timeout=5, resetOnInput=True, allowNegative=True)

The function timedInteger() and timedFloat() from pytimedinput accept the following parameters:

  • prompt, str: a string to show the user as a prompt when waiting for input.

    Defaults to an empty string.

  • timeout, int: how many seconds to wait before timing out.

    Defaults to 5 seconds, use -1 to disable.

  • resetOnInput, bool: Reset the timeout-timer any time user presses a key.

    Defaults to True.

  • allowNegative, bool: Whether to allow the user to enter a negative value or not.

The function returns a tuple of:

  • int/float or None: an integer or float, depending on which function was called or None, if no number was entered.

  • bool: whether the function timed out or not.

Example:

from pytimedinput import *
userNumber, timedOut = timedFloat("Enter a floating-point value: ")
if(not timedOut):
    if(userNumber == None):
        print("We wanted a number, but got none.")
    else:
        print(f"We should do some fancy maths with {userNumber}!")

Exceptions

All the functions require an interactive shell to function and will raise a Runtimerror-exception otherwise, which will need to be caught in any script that will be used both interactively and non-interactively.

License

MIT

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

pytimedinput-2.0.1.tar.gz (5.7 kB view details)

Uploaded Source

Built Distribution

pytimedinput-2.0.1-py3-none-any.whl (6.1 kB view details)

Uploaded Python 3

File details

Details for the file pytimedinput-2.0.1.tar.gz.

File metadata

  • Download URL: pytimedinput-2.0.1.tar.gz
  • Upload date:
  • Size: 5.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for pytimedinput-2.0.1.tar.gz
Algorithm Hash digest
SHA256 f680c9a51a5677ffd0d15334628eb2e9e15ddad4a2d9222e00bf6c0d77768f41
MD5 e892f7830b6acbb2d26ff6e28a96f9c4
BLAKE2b-256 1f224a13155366e99d78809bb05a92ee7644e5ca9e2d973ccb29cc304ce66c62

See more details on using hashes here.

File details

Details for the file pytimedinput-2.0.1-py3-none-any.whl.

File metadata

  • Download URL: pytimedinput-2.0.1-py3-none-any.whl
  • Upload date:
  • Size: 6.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for pytimedinput-2.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 dcef8f5ce713f59cace8dc45e4dfc0e5c7369d44d533d4fbb772fa84ca36a110
MD5 012ad296b80c86d39e39208fbeebf2b2
BLAKE2b-256 e3122f7379e94fd521d7b965ab18ca494e82e71fe26ea8744684421ddc9b9423

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