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.7.tar.gz
(6.9 kB
view details)
Built Distribution
File details
Details for the file fastapi-script-0.0.7.tar.gz
.
File metadata
- Download URL: fastapi-script-0.0.7.tar.gz
- Upload date:
- Size: 6.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5aa3d627867453de40d3deacd009b51cb36c96a03b9136af1cec48e58c2426af |
|
MD5 | fede271d31c5af78293d592b4149d6e2 |
|
BLAKE2b-256 | 7cf96b4a531d86295e7f313951c48e1ade4875eae0ee87b9f8ce6c4016e5ca61 |
File details
Details for the file fastapi_script-0.0.7-py3-none-any.whl
.
File metadata
- Download URL: fastapi_script-0.0.7-py3-none-any.whl
- Upload date:
- Size: 7.5 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 | ace475a2dac3cd005bdae706e18d9bc82c94e311c94d27ff144fabbf0f39aa33 |
|
MD5 | 6df9241acf9342b15875ce91b8def42f |
|
BLAKE2b-256 | b5a343029089eb65c80d9bb143930e00afb880210bee490009afda1556150e1f |