How to using PyPI publish a Python package
阅读原文时间:2022年04月19日阅读:1

How to using PyPI publish a Python package

PyPI & Python package

https://pypi.org/

make a file that can be both imported as a module and run as a script.

To do this, place script code inside if name == "main".

This ensures that it won't be run if the file is imported.

# module.py
def function():
   print("This is a module function")

if __name__=="__main__":
   print("This is a script")



# app.py
from module import function

function();



$ python3 module.py
# "This is a script"

$ python3 app.py
# This is a module function

When the Python interpreter reads a source file, it executes all of the code it finds in the file.

Before executing the code, it defines a few special variables.

For example, if the Python interpreter is running that module (the source file) as the main program, it sets the special name variable to have a value "main". If this file is being imported from another module, name will be set to the module's name.

project/
   LICENSE.txt
   README.txt
   setup.py
   emoji/
      __init__.py
      module.py
      module2.py
      ...

In Python, the term packaging refers to putting modules you have written in a standard format, so that other programmers can install and use them with ease.

This involves use of the modules setuptools and distutils.

The first step in packaging is to organize existing files correctly.

Place all of the files you want to put in a library in the same parent directory.

This directory should also contain a file called __init__.py, which can be blank but must be present in the directory.

This directory goes into another directory containing the readme and license, as well as an important file called setup.py.

init.py

setup.py

This contains the information necessary to assemble the package so it can be uploaded to PyPI and installed with pip (name, version, etc.).

from distutils.core import setup

setup(
   name='project',
   version='0.1dev',
   packages=['emoji',],
   license='MIT',
   long_description=open('README.txt').read(),
)

After creating the setup.py file, upload it to PyPI, or use the command line to create a binary distribution (an executable installer).

To build a source distribution, use the command line to navigate to the directory containing setup.py, and run the command python setup.py sdist.

Run python setup.py bdist or, for Windows, python setup.py bdist_wininst to build a binary distribution.

Use python setup.py register, followed by python setup.py sdist upload to upload a package.

Finally, install a package with python setup.py install.

#  build a source distribution
$ python setup.py sdist

# upload a package
$ python setup.py register

# build a binary distribution
$ python setup.py bdist

# install a package
$ python setup.py install

package a Python script to executable file

However, many computer users who are not programmers do not have Python installed.

Therefore, it is useful to package scripts as executable files for the relevant platform, such as the Windows or Mac operating systems.

This is not necessary for Linux, as most Linux users do have Python installed, and are able to run scripts as they are.

for Windows, use py2exe, PyInstaller, cx_Freeze

For Macs, use py2app, PyInstaller, cx_Freeze

Zen of Python

Beautiful is better than ugly.

Explicit is better than implicit.

Simple is better than complex.

Complex is better than complicated.

Flat is better than nested.

Sparse is better than dense.

Readability counts.

Special cases aren't special enough to break the rules.

Although practicality beats purity.

Errors should never pass silently.

Unless explicitly silenced.

In the face of ambiguity, refuse the temptation to guess.

There should be one-- and preferably only one --obvious way to do it.

Although that way may not be obvious at first unless you're Dutch.

Now is better than never.

Although never is often better than right now.

If the implementation is hard to explain, it's a bad idea.

If the implementation is easy to explain, it may be a good idea.

Namespaces are one honking great idea -- let's do more of those!

PEP 8

Python Enhancement Proposals (PEP)

PEP 8 is a style guide on the subject of writing readable code.

https://pypi.org/manage/projects/

https://packaging.python.org/

https://www.sololearn.com/Course/Python/

https://www.sololearn.com/Play/Python

https://www.sololearn.com/Certificate/Python/jpg/

https://www.sololearn.com/Profile/3476348/Python



xgqfrms 2012-2020

www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!