
Security News
MCP Steering Committee Launches Official MCP Registry in Preview
The MCP Steering Committee has launched the official MCP Registry in preview, a central hub for discovering and publishing MCP servers.
python-sample-app-mackes
Advanced tools
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.
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 python_sample_app ${your_main_package_name}
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
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!
$
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.
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
FAQs
A sample Python application with CLI entry point
We found that python-sample-app-mackes demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
The MCP Steering Committee has launched the official MCP Registry in preview, a central hub for discovering and publishing MCP servers.
Product
Socket’s new Pull Request Stories give security teams clear visibility into dependency risks and outcomes across scanned pull requests.
Research
/Security News
npm author Qix’s account was compromised, with malicious versions of popular packages like chalk-template, color-convert, and strip-ansi published.