Skip to main content

python-sample-app is a starter template for new python applications

Project description

Python Sample App

Python Sample App is a starter template for new python applications. You can clone it, edit some basic stuff and get started on your new app.

Installing

First set some variables:

your_project_name=<project_name>
your_main_package_name=<main_package_name>

Then clone or download this repository:

$ git clone https://github.com/becosta/python-sample-app.git
$ rm -rf python-sample-app/.git/

Or:

$ curl -LkSs https://api.github.com/repos/becosta/python-sample-app/tarball | tar -xvzp -C . ; mv becosta-python-sample-app-* python-sample-app

Next thing to do is to rename the project directory (python-sample-app) to your project's name.

$ mv python-sample-app ${your_project_name} && cd ${your_project_name}

Then you can move on to renaming the main package directory (python_sample_app).

$ mv kostsample ${your_main_package_name}

Application layout

Your new application layout is as following:

python-sample-app
├── apidoc/
|   └── .gitkeep
├── dist/
|   └── .gitkeep
├── doc/
|   └── .gitkeep
├── python_sample_app/
|   ├── test/
|   |   └── __init__.py
|   ├── __init__.py
|   └── main.py
├── scripts/
|   └── .gitkeep
├── .gitignore
├── LICENSE.md
├── README.md
└── setup.py

Editing to match your project needs

After this you need to edit setup.py: $ editor setup.py

name='<your_project>',
version='<your_project_version>',
description='<your_project_description>',
author='<your_name>',
author_email='<you@example.com>',
license="<your_project_license>",
url="<your_project_url>",
packages=['<your_project_main_package>'],
entry_points={
        'console_scripts': [
            '<your_command>=<your_project_main_package>.main:main',
        ],
},

Note that <your_command> is the name of the entry script that will be generated by $ pip install -e .. In other words this is the name of the command you'll use to call your application from the console later on. Also, note that you can have more than one entry point see the setuptools documentation for more information.

Once done, edit LICENSE.md, README.md and .gitignore according to your needs. If you don't need any of the apidoc, dist, doc and scripts directories you should remove them now.

Finally you can create your git repository, install your project locally and run it:

$ git init && git add .
$ git commit -m "Iniatial commit"
$ pip install -e .
$ <your_command>
Hello World!
$

Start coding

To get started, create a module in ${your_project_name}/${your_main_package_name} and call it in ${your_project_name}/${your_main_package_name}/main.py.

A simple example would be :

## ${your_project_name}/${your_main_package_name}/application.py
def class Application:
    def run(self):
        print("Hello World! From module application.")


# ${your_project_name}/${your_main_package_name}/main.py
import <your_main_package_name>.application
def main():
    <your_main_package_name>.application.Application().run()

You can then add more modules, either as simple as a flat file like application.py or more complex with a full directory tree.

Distributing your project

You can easily distribute your project to PyPi

Once you have created an account on PyPi, a pretty basic example would be:

pip install twine
python setup.py sdist
twine upload dist/*

See the PyPi tutorial for more information

Project details


Download files

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

Source Distribution

kostsample-1.0.6.tar.gz (3.1 kB view details)

Uploaded Source

File details

Details for the file kostsample-1.0.6.tar.gz.

File metadata

  • Download URL: kostsample-1.0.6.tar.gz
  • Upload date:
  • Size: 3.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.8.10

File hashes

Hashes for kostsample-1.0.6.tar.gz
Algorithm Hash digest
SHA256 f264d0a19efe4d342718b8375bcbfe2f116dab5c6193b16b099ab6f54b62bbf0
MD5 872d36d9f2af48451ccedb83a998e420
BLAKE2b-256 50a984d496e138c1c14eb22c17bb10d764011c6d3b21ed1e0dfaae145b5b8f8d

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