From 28ccfbfc51068a663a80764e14074df5edf2b5ba Mon Sep 17 00:00:00 2001
From: kongdeqiang <kongdeqiang960204@163.com>
Date: 星期五, 13 三月 2026 17:41:41 +0800
Subject: [PATCH] 提交

---
 runtime/python/http/server.py |  170 ++++++++++++++++++++++++--------------------------------
 1 files changed, 73 insertions(+), 97 deletions(-)

diff --git a/runtime/python/http/server.py b/runtime/python/http/server.py
index e4930a2..8ddcee2 100644
--- a/runtime/python/http/server.py
+++ b/runtime/python/http/server.py
@@ -4,6 +4,7 @@
 import uuid
 
 import aiofiles
+import ffmpeg
 import uvicorn
 from fastapi import FastAPI, File, UploadFile
 from modelscope.utils.logger import get_logger
@@ -14,71 +15,43 @@
 logger.setLevel(logging.INFO)
 
 parser = argparse.ArgumentParser()
-parser.add_argument("--host",
-                    type=str,
-                    default="0.0.0.0",
-                    required=False,
-                    help="host ip, localhost, 0.0.0.0")
-parser.add_argument("--port",
-                    type=int,
-                    default=8000,
-                    required=False,
-                    help="server port")
-parser.add_argument("--asr_model",
-                    type=str,
-                    default="paraformer-zh",
-                    help="asr model from https://github.com/alibaba-damo-academy/FunASR?tab=readme-ov-file#model-zoo")
-parser.add_argument("--asr_model_revision",
-                    type=str,
-                    default="v2.0.4",
-                    help="")
-parser.add_argument("--vad_model",
-                    type=str,
-                    default="fsmn-vad",
-                    help="vad model from https://github.com/alibaba-damo-academy/FunASR?tab=readme-ov-file#model-zoo")
-parser.add_argument("--vad_model_revision",
-                    type=str,
-                    default="v2.0.4",
-                    help="")
-parser.add_argument("--punc_model",
-                    type=str,
-                    default="ct-punc-c",
-                    help="model from https://github.com/alibaba-damo-academy/FunASR?tab=readme-ov-file#model-zoo")
-parser.add_argument("--punc_model_revision",
-                    type=str,
-                    default="v2.0.4",
-                    help="")
-parser.add_argument("--ngpu",
-                    type=int,
-                    default=1,
-                    help="0 for cpu, 1 for gpu")
-parser.add_argument("--device",
-                    type=str,
-                    default="cuda",
-                    help="cuda, cpu")
-parser.add_argument("--ncpu",
-                    type=int,
-                    default=4,
-                    help="cpu cores")
-parser.add_argument("--hotword_path",
-                    type=str,
-                    default='hotwords.txt',
-                    help="hot word txt path, only the hot word model works")
-parser.add_argument("--certfile",
-                    type=str,
-                    default=None,
-                    required=False,
-                    help="certfile for ssl")
-parser.add_argument("--keyfile",
-                    type=str,
-                    default=None,
-                    required=False,
-                    help="keyfile for ssl")
-parser.add_argument("--temp_dir",
-                    type=str,
-                    default="temp_dir/",
-                    required=False,
-                    help="temp dir")
+parser.add_argument(
+    "--host", type=str, default="0.0.0.0", required=False, help="host ip, localhost, 0.0.0.0"
+)
+parser.add_argument("--port", type=int, default=8000, required=False, help="server port")
+parser.add_argument(
+    "--asr_model",
+    type=str,
+    default="paraformer-zh",
+    help="asr model from https://github.com/alibaba-damo-academy/FunASR?tab=readme-ov-file#model-zoo",
+)
+parser.add_argument("--asr_model_revision", type=str, default="v2.0.4", help="")
+parser.add_argument(
+    "--vad_model",
+    type=str,
+    default="fsmn-vad",
+    help="vad model from https://github.com/alibaba-damo-academy/FunASR?tab=readme-ov-file#model-zoo",
+)
+parser.add_argument("--vad_model_revision", type=str, default="v2.0.4", help="")
+parser.add_argument(
+    "--punc_model",
+    type=str,
+    default="ct-punc-c",
+    help="model from https://github.com/alibaba-damo-academy/FunASR?tab=readme-ov-file#model-zoo",
+)
+parser.add_argument("--punc_model_revision", type=str, default="v2.0.4", help="")
+parser.add_argument("--ngpu", type=int, default=1, help="0 for cpu, 1 for gpu")
+parser.add_argument("--device", type=str, default="cuda", help="cuda, cpu")
+parser.add_argument("--ncpu", type=int, default=4, help="cpu cores")
+parser.add_argument(
+    "--hotword_path",
+    type=str,
+    default="hotwords.txt",
+    help="hot word txt path, only the hot word model works",
+)
+parser.add_argument("--certfile", type=str, default=None, required=False, help="certfile for ssl")
+parser.add_argument("--keyfile", type=str, default=None, required=False, help="keyfile for ssl")
+parser.add_argument("--temp_dir", type=str, default="temp_dir/", required=False, help="temp dir")
 args = parser.parse_args()
 logger.info("-----------  Configuration Arguments -----------")
 for arg, value in vars(args).items():
@@ -89,69 +62,72 @@
 
 logger.info("model loading")
 # load funasr model
-model = AutoModel(model=args.asr_model,
-                  model_revision=args.asr_model_revision,
-                  vad_model=args.vad_model,
-                  vad_model_revision=args.vad_model_revision,
-                  punc_model=args.punc_model,
-                  punc_model_revision=args.punc_model_revision,
-                  ngpu=args.ngpu,
-                  ncpu=args.ncpu,
-                  device=args.device,
-                  disable_pbar=True,
-                  disable_log=True)
+model = AutoModel(
+    model=args.asr_model,
+    model_revision=args.asr_model_revision,
+    vad_model=args.vad_model,
+    vad_model_revision=args.vad_model_revision,
+    punc_model=args.punc_model,
+    punc_model_revision=args.punc_model_revision,
+    ngpu=args.ngpu,
+    ncpu=args.ncpu,
+    device=args.device,
+    disable_pbar=True,
+    disable_log=True,
+)
 logger.info("loaded models!")
 
 app = FastAPI(title="FunASR")
 
 param_dict = {"sentence_timestamp": True, "batch_size_s": 300}
-
 if args.hotword_path is not None and os.path.exists(args.hotword_path):
-    with open(args.hotword_path, 'r', encoding='utf-8') as f:
+    with open(args.hotword_path, "r", encoding="utf-8") as f:
         lines = f.readlines()
         lines = [line.strip() for line in lines]
-    hotword = ' '.join(lines)
-    logger.info(f'鐑瘝锛歿hotword}')
-    param_dict['hotword'] = hotword
+    hotword = " ".join(lines)
+    logger.info(f"鐑瘝锛歿hotword}")
+    param_dict["hotword"] = hotword
 
 
 @app.post("/recognition")
 async def api_recognition(audio: UploadFile = File(..., description="audio file")):
-    suffix = audio.filename.split('.')[-1]
-    audio_path = f'{args.temp_dir}/{str(uuid.uuid1())}.{suffix}'
-    async with aiofiles.open(audio_path, 'wb') as out_file:
+    suffix = audio.filename.split(".")[-1]
+    audio_path = f"{args.temp_dir}/{str(uuid.uuid1())}.{suffix}"
+    async with aiofiles.open(audio_path, "wb") as out_file:
         content = await audio.read()
         await out_file.write(content)
-
-        try:
+    try:
         audio_bytes, _ = (
             ffmpeg.input(audio_path, threads=0)
             .output("-", format="s16le", acodec="pcm_s16le", ac=1, ar=16000)
             .run(cmd=["ffmpeg", "-nostdin"], capture_stdout=True, capture_stderr=True)
         )
     except Exception as e:
-        logger.error(f'璇诲彇闊抽鏂囦欢鍙戠敓閿欒锛岄敊璇俊鎭細{e}')
+        logger.error(f"璇诲彇闊抽鏂囦欢鍙戠敓閿欒锛岄敊璇俊鎭細{e}")
         return {"msg": "璇诲彇闊抽鏂囦欢鍙戠敓閿欒", "code": 1}
     rec_results = model.generate(input=audio_bytes, is_final=True, **param_dict)
     # 缁撴灉涓虹┖
-    if len(rec_results) == 0:
+    if len(rec_results[0]["text"] ) == 0:
         return {"text": "", "sentences": [], "code": 0}
-    elif len(rec_results) == 1:
+    elif len(rec_results[0]["text"] ) > 0:
         # 瑙f瀽璇嗗埆缁撴灉
         rec_result = rec_results[0]
-        text = rec_result['text']
+        text = rec_result["text"]
         sentences = []
-        for sentence in rec_result['sentence_info']:
+        for sentence in rec_result["sentence_info"]:
             # 姣忓彞璇濈殑鏃堕棿鎴�
-            sentences.append({'text': sentence['text'], 'start': sentence['start'], 'end': sentence['start']})
+            sentences.append(
+                {"text": sentence["text"], "start": sentence["start"], "end": sentence["end"]}
+            )
         ret = {"text": text, "sentences": sentences, "code": 0}
-        logger.info(f'璇嗗埆缁撴灉锛歿ret}')
+        logger.info(f"璇嗗埆缁撴灉锛歿ret}")
         return ret
     else:
-        logger.info(f'璇嗗埆缁撴灉锛歿rec_results}')
+        logger.info(f"璇嗗埆缁撴灉锛歿rec_results}")
         return {"msg": "鏈煡閿欒", "code": -1}
 
 
-
-if __name__ == '__main__':
-    uvicorn.run(app, host=args.host, port=args.port, ssl_keyfile=args.keyfile, ssl_certfile=args.certfile)
+if __name__ == "__main__":
+    uvicorn.run(
+        app, host=args.host, port=args.port, ssl_keyfile=args.keyfile, ssl_certfile=args.certfile
+    )

--
Gitblit v1.9.1