# Note: To use the 'upload' functionality of this file, you must: # $ pipenv install twine --dev
import io import os import sys from shutil import rmtree
from setuptools import find_packages, setup, Command
# Package meta-data. NAME = 'HandyToolsPy' DESCRIPTION = 'Handypy is a multifunctional Python tool library, which aims to provide developers with a series of convenient practical tools and simplify daily programming tasks.Whether it is processing data, operating file systems, or network requests, Handypy can provide you with efficient and reliable solutions.' URL = 'https://github.com/kimbleex/HandyToolsPy' EMAIL = 'kimbleex@outlook.com' AUTHOR = 'kimbleex' REQUIRES_PYTHON = '>=3.6.0' VERSION = '0.1.1'
# What packages are required for this module to be executed? REQUIRED = [ 'pandas', 'googletrans', ]
# What packages are optional? EXTRAS = { # 'fancy feature': ['django'], }
# The rest you shouldn't have to touch too much :) # ------------------------------------------------ # Except, perhaps the License and Trove Classifiers! # If you do change the License, remember to change the Trove Classifier for that!
here = os.path.abspath(os.path.dirname(__file__))
# Import the README and use it as the long-description. # Note: this will only work if 'README.md' is present in your MANIFEST.in file! try: with io.open(os.path.join(here, 'README.md'), encoding='utf-8') as f: long_description = '\n' + f.read() except FileNotFoundError: long_description = DESCRIPTION
# Load the package's __version__.py module as a dictionary. about = {} ifnot VERSION: project_slug = NAME.lower().replace("-", "_").replace(" ", "_") withopen(os.path.join(here, project_slug, '__version__.py')) as f: exec(f.read(), about) else: about['__version__'] = VERSION
self.status('Uploading the package to PyPI via Twine…') os.system('twine upload dist/*')
self.status('Pushing git tags…') os.system('git tag v{0}'.format(about['__version__'])) os.system('git push --tags')
sys.exit()
# Where the magic happens: setup( name=NAME, version=about['__version__'], description=DESCRIPTION, long_description=long_description, long_description_content_type='text/markdown', author=AUTHOR, author_email=EMAIL, python_requires=REQUIRES_PYTHON, url=URL, packages=find_packages(exclude=["tests", "*.tests", "*.tests.*", "tests.*"]), # If your package is a single module, use this instead of 'packages': # py_modules=['mypackage'],
# entry_points={ # 'console_scripts': ['mycli=mymodule:cli'], # }, install_requires=REQUIRED, extras_require=EXTRAS, include_package_data=True, license='MIT', classifiers=[ # Trove classifiers # Full list: https://pypi.python.org/pypi?%3Aaction=list_classifiers 'License :: OSI Approved :: MIT License', 'Programming Language :: Python', 'Programming Language :: Python :: 3.6', 'Programming Language :: Python :: 3.7', "Programming Language :: Python :: 3.8", "Programming Language :: Python :: 3.9", 'Programming Language :: Python :: 3.10', 'Programming Language :: Python :: 3.11', 'Programming Language :: Python :: 3.12', 'Programming Language :: Python :: Implementation :: CPython', 'Programming Language :: Python :: Implementation :: PyPy', ], # $ setup.py publish support. cmdclass={ 'upload': UploadCommand, }, )