Ask-question

Latest version: v1.2.8

Safety actively analyzes 687848 Python packages for vulnerabilities to keep your Python projects secure.

Scan your dependencies

1.2.8

[UPDATE] the unit test workflow
Ask Question

![PyPI - Python Version](https://img.shields.io/pypi/pyversions/ask_question)
![PyPI - Implementation](https://img.shields.io/pypi/implementation/ask_question)
![PyPI - Wheel](https://img.shields.io/pypi/wheel/ask_question)
![PyPI - Version](https://img.shields.io/pypi/v/ask_question?label=pypi%20package:%20ask_question)
![PyPI - Downloads](https://img.shields.io/pypi/dm/ask_question)
![PyPI - License](https://img.shields.io/pypi/l/ask_question)
![Execution status](https://github.com/Hanra-s-work/ask_question/actions/workflows/python-package.yml/badge.svg)
![GitHub Workflow Status (with event)](https://img.shields.io/github/actions/workflow/status/Hanra-s-work/ask_question/python-package.yml)
![GitHub repo size](https://img.shields.io/github/repo-size/Hanra-s-work/ask_question)
![GitHub Repo stars](https://img.shields.io/github/stars/Hanra-s-work/ask_question)
![GitHub commit activity (branch)](https://img.shields.io/github/commit-activity/m/Hanra-s-work/ask_question)
![GitHub last commit (branch)](https://img.shields.io/github/last-commit/Hanra-s-work/ask_question/main)

[![Static Badge](https://img.shields.io/badge/Buy_me_a_tea-Hanra-%235F7FFF?style=flat-square&logo=buymeacoffee&label=Buy%20me%20a%20coffee&labelColor=%235F7FFF&color=%23FFDD00&link=https%3A%2F%2Fwww.buymeacoffee.com%2Fhanra)](https://www.buymeacoffee.com/hanra)

Description

This is a python package I created in order to simplify the boiling process when asking the user a question via TTY.

Table of Content

1. [ask_question](ask-question)
2. [Description](description)
3. [Table of Content](table-of-content)
4. [Installation](installation)
1. [Using pip](using-pip)
2. [Using python](using-python)
5. [Usage](usage)
1. [Importing](importing)
2. [Initialising](initialising)
3. [Calling the pause function](calling-the-pause-function)
4. [Asking a question](asking-a-question)
1. [Where do you live ?](where-do-you-live)
2. [How old are you ?](how-old-are-you)
3. [Do you like sugar ?](do-you-like-sugar)
6. [Available boiling](available-boiling)
7. [Change the initialisation content](change-the-initialisation-content)
1. [Changing the forbidden characters](changing-the-forbidden-characters)
2. [Changing the description](changing-the-descriptions)
3. [Changing both](changing-both)
8. [Author](author)
9. [Version](version)

Installation

Using pip

sh
pip install -U ask-question


Using python

Under windows:

bat
py -m pip install -U ask-question


Under Linux/Mac OS:

sh
python3 -m pip install -U ask-question


Usage

Importing

py
import ask_question as aq


Initialising

The generic class is: `AskQuestion(human_type:dict={}, illegal_characters_nb:str="")`

py
AQI = aq.AskQuestion()


Calling the pause function

The generic function is:

py
pause(self, pause_message:str="Press enter to continue...")


The output is: None

py
AQI.pause("Press enter to continue ...")


Asking a Question

The generic function to ask a question is:

py
ask_question(self, question:str, answer_type:str)


The outputs of this functions can be:

* str = a string
* int = a whole number
* float = a floating number

Where do you live

py
answer = AQI.ask_question("Where are you from? ", "str")
print(f"You live in {answer}!")


How old are you

py
answer = AQI.ask_question("How old are you?", "uint")
ADD_S = ""
if answer > 1:
ADD_S = "s"
print(f"You are {answer} year{ADD_S} old !")


Do you like sugar

py
answer = AQI.ask_question("Do you like sugar? [(Y)es/(n)o]: ", "bool")
if answer == True:
print("You like sugar !")
else:
print("You do not like sugar.")


Available boiling

Here are all the available boiling options and their explanation:

* int = whole number (-1, 0, 1, 2, 3, etc...)
* float = floating number (-1.2, 0.1, 1.2, etc...)
* uint = whole positive number (0, 1, 2, etc...)
* ufloat = whole positive floating number (0.1, 1.2, etc ...)
* num = numeric (numbers from 0 onwards)
* alnum = alphanumeric (only numbers and the alphabet)
* isalpha = alphabet (from a to z and A to Z)
* char = alphabet (from a to z and A to Z)
* ascii = ascii Table
* str = string (any character you can type)
* version = version (numbers seperated by '.' characters)
* ver = version (numbers seperated by '.' characters)
* bool = boolean (yes/True/1 or no/False/0 answer type)

Change the initialisation content

When initialising the class it is possible to change the forbidden characters and/or the descriptions of the available types.

changing the forbidden characters

py
import ask_question as aq
illegal_characters = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ!\"$%&\'()*+,-./:;<=>?[\]^_`{|}~ \t\n\r\x0b\x0c"
illegal_characters = illegal_characters.replace("0123456789","")
AQI = aq.AskQuestion(dict(), illegal_characters)


This initialisation has changed the characters that will be allowed for the number conversion in the 'int' and 'float' options.

Changing the descriptions

py
import ask_question as aq
human_type = {
"int":"whole number (-1, 0, 1, 2, 3, etc...)",
"float":"floating number (-1.2, 0.1, 1.2, etc...)",
"uint":"whole positive number (0, 1, 2, etc...)",
"ufloat":"whole positive floating number (0.1, 1.2, etc ...)",
"num":"numeric (numbers from 0 onwards)",
"alnum":"alphanumeric (only numbers and the alphabet)",
"isalpha":"alphabet (from a to z and A to Z)",
"char":"alphabet (from a to z and A to Z)",
"ascii":"ascii Table",
"str":"string (any character you can type)",
"version":"version (numbers seperated by '.' characters)",
"ver":"version (numbers seperated by '.' characters)",
"bool":"boolean (yes/True/1 or no/False/0 answer type)",
}
AQI = aq.AskQuestion(human_type)


This initialisation has changed the descriptions for the types.
When the user will enter a wrong answer, the description displayed for the type you were expecting will be taken from the human_type dictionnary you have entered.

Changing both

py
import ask_question as aq
illegal_characters = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ!\"$%&\'()*+,-./:;<=>?[\]^_`{|}~ \t\n\r\x0b\x0c"
illegal_characters = illegal_characters.replace("0123456789","")
human_type = {
"int":"whole number (-1, 0, 1, 2, 3, etc...)",
"float":"floating number (-1.2, 0.1, 1.2, etc...)",
"uint":"whole positive number (0, 1, 2, etc...)",
"ufloat":"whole positive floating number (0.1, 1.2, etc ...)",
"num":"numeric (numbers from 0 onwards)",
"alnum":"alphanumeric (only numbers and the alphabet)",
"isalpha":"alphabet (from a to z and A to Z)",
"char":"alphabet (from a to z and A to Z)",
"ascii":"ascii Table",
"str":"string (any character you can type)",
"version":"version (numbers seperated by '.' characters)",
"ver":"version (numbers seperated by '.' characters)",
"bool":"boolean (yes/True/1 or no/False/0 answer type)",
}
AQI = aq.AskQuestion(human_type)


You have now impacted the int and float typing as well as the 'type' descriptions.

Author

This module was written by (c) Henry Letellier
Attributions are appreciated.

Quick way (I assume you have already initialised the class):

py
print(f"AskQuestion is written by {AQI.author}")


Version

1.0.0

An easy way to display the version is:

py
import ask_question as aq
print(f"Version : {aq.__Version__}")

log
[UPDATE] the unit test workflow

Links

Releases

Has known vulnerabilities

© 2024 Safety CLI Cybersecurity Inc. All Rights Reserved.