Sneller pakketten bouwen met templates

Python-pakketten ontwikkelen

James Fulton

Climate informatics researcher

Templates

  • Python-pakketten hebben veel extra bestanden
  • Er is veel om te onthouden
  • Templates regelen veel hiervan

Pakket-bestandsstructuur

.
|-- example_package
|   |-- __init__.py
|   `-- example_package.py
|-- tests
|   |-- __init__.py
|   `-- test_example_package.py
|-- README.rst     <-
|-- LICENSE        <-- veel
|-- MANIFEST.in    <-- extra
|-- tox.ini        <--
|-- setup.py       <-- bestanden
`-- setup.cfg      <--
Python-pakketten ontwikkelen

cookiecutter

  • Te gebruiken om lege Python-pakketten te maken
  • Maakt alle extra bestanden aan die je pakket nodig heeft

Pakket-bestandsstructuur

.
|-- example_package
|   |-- __init__.py
|   `-- example_package.py
|-- tests
|   |-- __init__.py
|   `-- test_example_package.py
|-- README.rst
|-- LICENSE
|-- MANIFEST.in
|-- tox.ini
|-- setup.py
`-- setup.cfg
Python-pakketten ontwikkelen

Cookiecutter gebruiken

cookiecutter <template-url>
Python-pakketten ontwikkelen

Cookiecutter gebruiken

cookiecutter https://github.com/audreyr/cookiecutter-pypackage
  • Meer templates hier
Python-pakketten ontwikkelen

Cookiecutter gebruiken

cookiecutter https://github.com/audreyr/cookiecutter-pypackage
full_name [Audrey Roy Greenfeld]:
Python-pakketten ontwikkelen

Cookiecutter gebruiken

cookiecutter https://github.com/audreyr/cookiecutter-pypackage
full_name [Audrey Roy Greenfeld]: James Fulton




  • Vul je naam in en druk op Enter om verder te gaan
Python-pakketten ontwikkelen

Cookiecutter gebruiken

cookiecutter https://github.com/audreyr/cookiecutter-pypackage
full_name [Audrey Roy Greenfeld]: James Fulton

email [[email protected]]: [email protected] github_username [audreyr]: MyUsername
project_name [Python Boilerplate]: mysklearn project_slug [mysklearn]: mysklearn
  • Project slug - de name gebruikt in pip install name
Python-pakketten ontwikkelen

Cookiecutter gebruiken

cookiecutter https://github.com/audreyr/cookiecutter-pypackage
...
project_short_description [Python Boilerplate ...]: A Python package for linear 
    regression.

pypi_username [MyUsername]: version [0.1.0]:
Python-pakketten ontwikkelen

Cookiecutter gebruiken

cookiecutter https://github.com/audreyr/cookiecutter-pypackage
...
use_pytest [n]: y
use_pypi_deployment_with_travis [y]: n
add_pyup_badge [n]: n
Python-pakketten ontwikkelen

Cookiecutter gebruiken

cookiecutter https://github.com/audreyr/cookiecutter-pypackage
...
Select command_line_interface:
1 - Click
2 - Argparse
3 - No command-line interface
Choose from 1, 2, 3 [1]: 3

create_author_file [y]: y
Python-pakketten ontwikkelen

Cookiecutter gebruiken

cookiecutter https://github.com/audreyr/cookiecutter-pypackage
...
Select open_source_license:
1 - MIT license
2 - BSD license
3 - ISC license
4 - Apache Software License 2.0
5 - GNU General Public License v3
6 - Not open source
Choose from 1, 2, 3, 4, 5, 6 [1]: 6
Python-pakketten ontwikkelen

Template-uitvoer

mysklearn/
|-- mysklearn/
|   |-- __init__.py
|   `-- mysklearn.py
|-- tests/
|   |-- __init__.py
|   `-- test_mysklearn.py
|-- MANIFEST.in
|-- README.rst
|-- requirements_dev.txt
|-- setup.cfg
|-- setup.py
|-- tox.ini

|-- AUTHORS.rst |-- CONTRIBUTING.rst |-- HISTORY.rst `-- Makefile

In het bestand AUTHORS.rst

=======
Credits
=======

Development Lead
________________

* James Fulton <[email protected]>

Contributors
____________

Nog niemand. Waarom jij niet als eerste?
Python-pakketten ontwikkelen

Template-uitvoer

mysklearn/
|-- mysklearn/
|-- tests/
|-- MANIFEST.in
|-- README.rst
|-- requirements_dev.txt
|-- setup.cfg
|-- setup.py
|-- tox.ini
...
...
|-- docs/
|-- .github/
|-- .editorconfig
|-- .gitignore
`-- .travis.yml
Python-pakketten ontwikkelen

Laten we oefenen!

Python-pakketten ontwikkelen

Preparing Video For Download...