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.5.tar.gz
(6.4 kB
view details)
Built Distribution
File details
Details for the file fastapi-script-0.0.5.tar.gz
.
File metadata
- Download URL: fastapi-script-0.0.5.tar.gz
- Upload date:
- Size: 6.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d182c59adae36a1b280576804f045fd0891efdccb0016e15a24cf0b274fce1a5 |
|
MD5 | 05de27fdfde61b60b1acdf60c0e0148e |
|
BLAKE2b-256 | 3185d90f31a47086fe541a01945750f8186a2f4a7468cc56e4673376005eee0c |
File details
Details for the file fastapi_script-0.0.5-py3-none-any.whl
.
File metadata
- Download URL: fastapi_script-0.0.5-py3-none-any.whl
- Upload date:
- Size: 7.2 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 | b4c8bab806aab25e537f4e8f37e8b0d95c7e0b23e3bf5a16615edfa62a7f2a1c |
|
MD5 | e26d4be684b6aa9eb8614e1d2f3b9274 |
|
BLAKE2b-256 | 2c8b31d988548cb031ef65684be6e0a01c668ee8c8141ecaa37af1d8e123ed4f |