Skip to main content

Advanced mathematical captcha generator and

Project description

ADV-Math-captcha

An advanced mathematical captcha for simple human verification.

How to use

This is an example to make an verification:

from adv_math_captcha import Captcha


if __name__ == '__main__':
    formula1 = Captcha(5, 4, 15, 10, 50, 5, 5)
    inp = input("Solve this simple question: {0} = ".format(formula1.formula_str))
    if formula1.verify(float(inp)):
        print("Verify success!")
    else:
        print("Verify failed! The correct answer is {0:.0f}!".format(float(formula1.evaluation)))

Usage

This module only provides one class with only one method. To make a captcha, just use Captcha(difficulty, term, number_range), which is the shortest form. If you wanna use more parameters, use Captcha(difficulty, term, number_range, factor_range, exponentiation_range, exp_base_range, exp_index_range)

Details: (All the parameters are integers)

  • difficulty: Decides the difficulty of the generated expression. Valid value is 1-5 in integer.
    • 1: Only additions
    • 2: Additions and subtractions
    • 3: Operations in 2, with Mutliplications and divisions (For divisions, the result will always be an integer)
    • 4: Operations in 3, with exponentiation calculations
    • 5: Operations in 4, with logarithm calculations (The result will always in simple form to insure the result is reducable, for example, 'ln(e^3)', 'log_2 (8)')
  • term: Determines how many items will appear in an expression. Althogh there is no limits, don't be too much, or it will be hard to get the answer. :) (P.S. an division will be counted as one item. E.g. (6 / 3) )
  • number_range: Determines the range of the coefficient.
  • factor_range: Determines the range of division results and dominators. Default value is 10.
  • exponentiation_range: Determines the range of exponential calculation. Default value is 50.
  • exp_base_range: Determines the range of base number. Default value is 6.
  • exp_index_range: Determines the range of index number. Default value is 5.

Once you initialized an captcha object, you can get the expression string from Captcha.formula_str variable in class, or make an verification using the Captcha.verify(user_input). A True will be returned if the verification is successful, or False if failed.

You can also get the actual value of the expression from Captcha.evaluation variable.

About

If you want to contact me, mail to mailto

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

File details

Details for the file adv_math_captcha_ostrichb-0.9.10-py3-none-any.whl.

File metadata

  • Download URL: adv_math_captcha_ostrichb-0.9.10-py3-none-any.whl
  • Upload date:
  • Size: 17.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.0 importlib_metadata/4.8.2 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for adv_math_captcha_ostrichb-0.9.10-py3-none-any.whl
Algorithm Hash digest
SHA256 b09cdcf3b32cc68049bc44af44c4d0beea6ae74b395f691d5c6be9588d3071a1
MD5 8e1329461602222512044b80bb2e1fb3
BLAKE2b-256 741ea960da67084b9830cb8cbee06cbe1c18919e74599b5c1db2a2aefd5404b1

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