An extension for FastAPI
Project description
FastAPI-Script
An extension for FastAPI.
Getting Started
Installation
First you have to install fastapi-script
like this:
pip install fastapi-script
Quick Tutorial
We need to create a Python module to manage your script commands, such as manage.py
:
import asyncio
from fastapi import FastAPI
from fastapi_script import Manager
app = FastAPI()
manager = Manager(app)
@manager.command
async def test_without_params():
print('test_without_params')
@manager.command
async def test_one_params(name):
print(f'test_one_params, name: {name}')
@manager.command
async def test_many_params(name, age=0):
print(f'test_many_params, name: {name}, age: {age}')
@manager.option('-n', '--name', dest='name', help='input your name')
async def option_one_params(name):
print(f'option_one_params, name: {name}')
@manager.option('-n', '--name', dest='name', help='input your name')
@manager.option('-s', '--score', dest='score', help='input your score')
async def option_many_params(name, score):
print(f'option_many_params, name: {name}, score: {score}')
if __name__ == '__main__':
asyncio.run(manager.run())
Next, we can manipulate the above script like this:
$ python manage.py test_without_params
test_with_no_param
$ python manage.py test_one_params laozhang
test_one_params, name: laozhang
$ python manage.py test_many_params laozhang --age 20
test_many_params, name: laozhang, age: 20
$ python manage.py option_one_params -n laozhang
option_one_params, name: laozhang
$ python manage.py option_one_params --name laozhang
option_one_params, name: laozhang
$ python manage.py option_many_params -n laozhang -s 90
option_many_params, name: laozhang, score: 90
$ python manage.py option_many_params --name laozhang --score 90
option_many_params, name: laozhang, score: 90
We can use the --help
parameter to view all of the currently managed commands:
python manage.py --help
In addition to using the decorator above, we can also use the inherited Command class to do this:
import asyncio
from fastapi import FastAPI
from fastapi_script import Manager, Command, Option
app = FastAPI()
manager = Manager(app)
class HelloCommand(Command):
def get_options(self):
return [
Option('-n', '--name', dest='name', help='input your name'),
Option('-s', '--score', dest='score', help='input your score')
]
def run(self, *args, **kwargs):
print(f'hello command, args: {args}, kwargs: {kwargs}')
manager.add_command('hello', HelloCommand())
if __name__ == '__main__':
asyncio.run(manager.run())
And then we can use it like this:
$ python manage.py hello -n laozhang -s 90
hello command, args: (), kwargs: {'name': 'laozhang', 'score': '90'}
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
fastapi-script-0.0.4.tar.gz
(5.5 kB
view details)
Built Distribution
File details
Details for the file fastapi-script-0.0.4.tar.gz
.
File metadata
- Download URL: fastapi-script-0.0.4.tar.gz
- Upload date:
- Size: 5.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3df8392b9a73caa988bf36909f99afc94a838ab4b79e80b3be09061dde8133ac |
|
MD5 | ba6bbbd8baf1534c26c92ffcb9651a24 |
|
BLAKE2b-256 | fcee72446a0c2ed98a846dd0fec714ac2bdb7a1332c63e0f537da0be5592bc67 |
File details
Details for the file fastapi_script-0.0.4-py3-none-any.whl
.
File metadata
- Download URL: fastapi_script-0.0.4-py3-none-any.whl
- Upload date:
- Size: 6.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 895e9345d10c3ea628f70b58c798d4be0aa4717c1e492373dae980622da8cdc1 |
|
MD5 | 731f9ce1a472e98778b86929dd47c9a2 |
|
BLAKE2b-256 | b9e23f8f1d7eb6d77d7fe9e11b4e2d4812a5ead48ae982b61fa1da2da84f2d81 |