MeUtils 2024.3.4.13.4.45__py3-none-any.whl → 2025.1.16.17.15.52__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {MeUtils-2024.3.4.13.4.45.dist-info → MeUtils-2025.1.16.17.15.52.dist-info}/METADATA +38 -32
- MeUtils-2025.1.16.17.15.52.dist-info/RECORD +864 -0
- {MeUtils-2024.3.4.13.4.45.dist-info → MeUtils-2025.1.16.17.15.52.dist-info}/WHEEL +1 -1
- {MeUtils-2024.3.4.13.4.45.dist-info → MeUtils-2025.1.16.17.15.52.dist-info}/entry_points.txt +1 -0
- apps/spider.py +24 -8
- examples/_openaisdk/4v.py +110 -0
- examples/_openaisdk/__init__.py +11 -0
- examples/_openaisdk/baichuan.py +38 -0
- examples/_openaisdk/bpo.py +138 -0
- examples/_openaisdk/chat_latex.py +95 -0
- examples/_openaisdk/chattts.py +85 -0
- examples/_openaisdk/copilot.py +48 -0
- examples/_openaisdk/dalle3.py +48 -0
- examples/_openaisdk/deeplx.py +31 -0
- examples/_openaisdk/demo.py +77 -0
- examples/_openaisdk/embeddings.py +34 -0
- examples/_openaisdk/gpt4all.py +69 -0
- examples/_openaisdk/gpt_fc.py +23 -0
- examples/_openaisdk/gr_vl.py +46 -0
- examples/_openaisdk/json_mode.py +12 -0
- examples/_openaisdk/kimi.py +91 -0
- examples/_openaisdk/kimi_qa.py +57 -0
- examples/_openaisdk/minimax.py +75 -0
- examples/_openaisdk/open_router.py +48 -0
- examples/_openaisdk/openai_aiplus.py +54 -0
- examples/_openaisdk/openai_audio.py +20 -0
- examples/_openaisdk/openai_baichuan.py +59 -0
- examples/_openaisdk/openai_cache.py +37 -0
- examples/_openaisdk/openai_chatfire.py +228 -0
- examples/_openaisdk/openai_chatfire_all.py +166 -0
- examples/_openaisdk/openai_deepinfra.py +55 -0
- examples/_openaisdk/openai_deepseek.py +29 -0
- examples/_openaisdk/openai_doubao.py +43 -0
- examples/_openaisdk/openai_embeddings.py +36 -0
- examples/_openaisdk/openai_files.py +57 -0
- examples/_openaisdk/openai_gitee.py +33 -0
- examples/_openaisdk/openai_god.py +45 -0
- examples/_openaisdk/openai_groq.py +240 -0
- examples/_openaisdk/openai_images.py +203 -0
- examples/_openaisdk/openai_json.py +78 -0
- examples/_openaisdk/openai_lingyi.py +59 -0
- examples/_openaisdk/openai_modelscope.py +54 -0
- examples/_openaisdk/openai_moon.py +55 -0
- examples/_openaisdk/openai_oi.py +61 -0
- examples/_openaisdk/openai_ppu.py +47 -0
- examples/_openaisdk/openai_qwen.py +58 -0
- examples/_openaisdk/openai_search.py +42 -0
- examples/_openaisdk/openai_sensenova.py +81 -0
- examples/_openaisdk/openai_siliconflow.py +52 -0
- examples/_openaisdk/openai_step.py +45 -0
- examples/_openaisdk/openai_test.py +66 -0
- examples/_openaisdk/openai_together.py +57 -0
- examples/_openaisdk/openai_tune.py +38 -0
- examples/_openaisdk/openai_zhipu.py +59 -0
- examples/_openaisdk/ppu.py +28 -0
- examples/_openaisdk/rag.py +54 -0
- examples/_openaisdk/rag_.py +26 -0
- examples/_openaisdk/test.py +52 -0
- examples/_openaisdk/x.py +32 -0
- examples/_openaisdk/xx.py +29 -0
- examples/_openaisdk/zhipu_files.py +47 -0
- examples/_openaisdk/zhipu_/346/231/272/350/203/275/344/275/223.py +45 -0
- examples/_openaisdk//345/205/234/345/272/225/346/265/213/350/257/225.py +50 -0
- examples/_openaisdk//345/244/232/346/250/241/346/200/201/346/265/213/350/257/225.py +76 -0
- examples/_openaisdk//345/244/232/346/250/241/346/200/201/346/265/213/350/257/225_.py +56 -0
- examples/_openaisdk//346/226/207/344/273/266/351/227/256/347/255/224.py +36 -0
- examples/_openaisdk//346/226/207/346/241/243/350/247/243/346/236/220.py +34 -0
- examples/_openaisdk//346/250/241/345/236/213/346/265/213/350/257/225.py +53 -0
- examples/_openaisdk//351/230/277/351/207/214.py +80 -0
- {meutils/serving/jina/__demo → examples/ann}/__init__.py +1 -1
- examples/ann/main.py +31 -0
- examples/apis/kl.py +28 -0
- examples/apis/x.py +17 -0
- examples/apis/xx.py +17 -0
- examples/arq_demo/demo.py +3 -0
- examples/backgroundtasks.py +25 -0
- examples/bserver.py +513 -21
- examples/cache_demo/HermesCache_demo.py +81 -0
- examples/cache_demo/acacge.py +26 -0
- examples/cache_demo/x.py +31 -0
- {meutils/docarray_utils → examples/caches}/__init__.py +1 -1
- examples/caches/llmcache.py +18 -0
- examples/celery_demo/product_task.py +2 -0
- examples/demo.py +17 -1
- examples/fastapi_caching.py +59 -0
- {meutils/dependencies → examples/gr}/__init__.py +1 -1
- examples/gr/d.py +22 -0
- examples/gr/demo.py +30 -0
- examples/ip2/345/234/260/345/214/272.py +16 -0
- examples/jinja2_demo/j2_demo.py +20 -1
- examples/json/346/240/207/345/207/206/345/214/226.py +54 -0
- examples/md.py +29 -0
- {meutils/serving/jina → examples/nesc}/__init__.py +1 -1
- examples/nesc/main.py +76 -0
- examples/orm/mysql_orm.py +113 -0
- examples/orm/sql_creater.py +57 -0
- examples/orm/sqlm.py +134 -0
- examples/rq_demo/fns.py +18 -0
- examples/rq_demo/redis/351/230/237/345/210/227.py +14 -7
- examples/rq_demo/redis/351/230/237/345/210/227_add_chatfire.py +30 -0
- examples/size_map.py +43 -0
- examples/test.py +59 -0
- examples/webs/__init__.py +11 -0
- examples/webs/main.py +34 -0
- examples/x.py +13 -0
- examples//345/216/273/346/260/264/345/215/260.py +20 -0
- examples//346/226/207/346/241/243/346/231/272/350/203/275/__init__.py +11 -0
- meutils/_utils.py +15 -6
- meutils/ai_audio/asr/__init__.py +3 -2
- meutils/ai_audio/asr/cf_asr.py +53 -0
- meutils/ai_audio/asr/de.py +11 -0
- meutils/ai_audio/asr/fast_asr.py +15 -7
- meutils/ai_audio/asr/openai_asr.py +83 -6
- meutils/ai_audio/fast_asr.py +8 -4
- meutils/ai_audio/tts/EdgeTTS.py +33 -7
- meutils/ai_audio/tts/openai_tts.py +24 -20
- meutils/ai_audio/tts/tts_ui.py +1 -0
- meutils/ai_audio/utils.py +9 -0
- meutils/ai_cv/__init__.py +0 -1
- meutils/ai_cv/ocr.py +3 -2
- meutils/ai_cv/utils.py +154 -0
- meutils/ai_video/avmerge.py +6 -0
- meutils/ai_video/video.py +11 -2
- meutils/{api → apis}/__init__.py +1 -1
- meutils/apis/ali_apis.py +60 -0
- meutils/apis/audio/__init__.py +10 -0
- meutils/apis/audio/deepinfra.py +59 -0
- meutils/apis/audio/fish.py +248 -0
- meutils/apis/baidu/__init__.py +9 -0
- meutils/apis/baidu/bdaitpzs.py +229 -0
- meutils/apis/baidu/test.py +78 -0
- meutils/apis/chatglm/__init__.py +11 -0
- meutils/apis/chatglm/glm_video.py +273 -0
- meutils/apis/chatglm/glm_video_api.py +116 -0
- meutils/apis/chatglm/images.py +63 -0
- meutils/apis/chatglm/temp.py +259 -0
- meutils/apis/chatglm/x.py +31 -0
- meutils/{api → apis}/common.py +10 -6
- meutils/apis/fal/__init__.py +11 -0
- meutils/apis/fal/files.py +53 -0
- meutils/apis/fal/images.py +57 -0
- meutils/apis/fal/images_.py +72 -0
- meutils/apis/fal/videos.py +77 -0
- meutils/apis/firecrawl.py +45 -0
- meutils/apis/gitee/__init__.py +11 -0
- meutils/apis/gitee/images/__init__.py +9 -0
- meutils/apis/gitee/images/kolors.py +99 -0
- meutils/apis/hailuoai/__init__.py +11 -0
- meutils/apis/hailuoai/demo.py +34 -0
- meutils/apis/hailuoai/hasha_new.py +248 -0
- meutils/apis/hailuoai/music.py +11 -0
- meutils/apis/hailuoai/upload.py +116 -0
- meutils/apis/hailuoai/videos.py +460 -0
- meutils/apis/hailuoai/yy.py +242 -0
- meutils/apis/hf/__init__.py +11 -0
- meutils/apis/hf/got_ocr.py +64 -0
- meutils/apis/hf/gradio.py +34 -0
- meutils/apis/hf/hivisionidphotos.py +80 -0
- meutils/apis/hf/kolors.py +68 -0
- meutils/apis/hf/kolors_virtual_try_on.py +107 -0
- meutils/apis/hf/r.py +53 -0
- meutils/apis/hf/x.py +26 -0
- meutils/apis/hf//350/257/201/344/273/266/347/205/247.py +41 -0
- meutils/apis/hunyuan/__init__.py +11 -0
- meutils/apis/hunyuan/image_tools.py +84 -0
- meutils/apis/images/__init__.py +11 -0
- meutils/apis/images/deepinfra.py +92 -0
- meutils/apis/images/demo.py +150 -0
- meutils/apis/images/eidt.py +36 -0
- meutils/apis/images/flux/__init__.py +11 -0
- meutils/apis/images/flux/fluxpro.py +108 -0
- meutils/apis/images/flux/mystic.py +116 -0
- meutils/apis/images/ideogram/__init__.py +10 -0
- meutils/apis/images/ideogram/ideogram_images.py +193 -0
- meutils/apis/images/prodia/__init__.py +12 -0
- meutils/apis/images/prodia/faceswap.py +76 -0
- meutils/apis/images/recraft.py +152 -0
- meutils/apis/images/virtual_try_on/__init__.py +11 -0
- meutils/apis/images/virtual_try_on/images.py +65 -0
- meutils/apis/jiema/24mail.py +96 -0
- meutils/apis/jiema/__init__.py +11 -0
- meutils/apis/jiema/yezi.py +97 -0
- meutils/apis/jimeng/__init__.py +11 -0
- meutils/apis/jimeng/common.py +328 -0
- meutils/apis/jimeng/doubao.py +68 -0
- meutils/apis/jimeng/doubao_utils.py +175 -0
- meutils/apis/jimeng/files.py +263 -0
- meutils/apis/jimeng/images.py +140 -0
- meutils/apis/jimeng/lip_sync.py +11 -0
- meutils/apis/jina.py +55 -0
- meutils/apis/kling/__init__.py +11 -0
- meutils/apis/kling/api.py +60 -0
- meutils/apis/kling/images.py +174 -0
- meutils/apis/kling/kolors_virtual_try_on.py +111 -0
- meutils/apis/kling/kolors_virtual_try_on_web.py +126 -0
- meutils/apis/kling/videos.py +67 -0
- meutils/apis/kling//351/211/264/346/235/203.py +34 -0
- meutils/apis/kuaidi.py +32 -0
- meutils/apis/kuaishou/__init__.py +10 -0
- meutils/apis/kuaishou/klingai.py +523 -0
- meutils/apis/kuaishou/klingai_video.py +197 -0
- meutils/apis/kuaishou/kolors.py +189 -0
- meutils/apis/llm_qa.py +55 -0
- meutils/apis/luma/__init__.py +11 -0
- meutils/apis/luma/luma.py +123 -0
- meutils/apis/minicpm/__init__.py +9 -0
- meutils/apis/minicpm/luca.py +137 -0
- meutils/apis/monica/__init__.py +11 -0
- meutils/apis/monica/llm.py +11 -0
- meutils/apis/napkin/__init__.py +11 -0
- meutils/apis/napkin/icons.py +42 -0
- meutils/apis/niutrans.py +73 -0
- meutils/apis/oneapi/__init__.py +11 -0
- meutils/apis/oneapi/channel.py +68 -0
- meutils/apis/oneapi/common.py +135 -0
- meutils/apis/oneapi/log.py +47 -0
- meutils/apis/oneapi/token.py +48 -0
- meutils/apis/oneapi/token_.py +112 -0
- meutils/apis/oneapi/user.py +100 -0
- meutils/apis/oneapi/utils.py +47 -0
- meutils/apis/pixverse/__init__.py +11 -0
- meutils/apis/pixverse/pixverse.py +150 -0
- meutils/apis/proxy/__init__.py +11 -0
- meutils/apis/proxy/ips.py +178 -0
- meutils/apis/remini/__init__.py +11 -0
- meutils/apis/remini/remini.py +89 -0
- meutils/apis/replicateai/__init__.py +11 -0
- meutils/apis/replicateai/images.py +79 -0
- meutils/apis/replicateai/raw.py +53 -0
- meutils/apis/runwayml/__init__.py +10 -0
- meutils/apis/runwayml/gen.py +143 -0
- meutils/apis/search/__init__.py +11 -0
- meutils/apis/search/baichuan.py +11 -0
- meutils/apis/search/metaso.py +218 -0
- meutils/apis/search/metaso_.py +77 -0
- meutils/apis/search/n.py +99 -0
- meutils/apis/search/searxng.py +42 -0
- meutils/apis/search_music.py +39 -0
- meutils/apis/siliconflow/__init__.py +9 -0
- meutils/apis/siliconflow/audio.py +63 -0
- meutils/apis/siliconflow/image_to_image.py +116 -0
- meutils/apis/siliconflow/images.py +154 -0
- meutils/apis/siliconflow/rerankers.py +40 -0
- meutils/apis/siliconflow/text_to_image.py +132 -0
- meutils/apis/siliconflow/utils.py +66 -0
- meutils/apis/siliconflow/videos.py +102 -0
- meutils/apis/sunoai/__init__.py +10 -0
- meutils/apis/sunoai/haimian.py +135 -0
- meutils/apis/sunoai/suno.py +373 -0
- meutils/apis/textcard/__init__.py +11 -0
- meutils/apis/textcard/demo.py +25 -0
- meutils/apis/textcard/hanyuxinjie.py +81 -0
- meutils/apis/textin.py +159 -0
- meutils/apis/to_image/__init__.py +11 -0
- meutils/apis/to_image/html2image.py +29 -0
- meutils/apis/to_image/md.py +29 -0
- meutils/apis/to_image/url2image.py +41 -0
- meutils/apis/together/__init__.py +11 -0
- meutils/apis/together/images.py +80 -0
- meutils/apis/translator/__init__.py +9 -0
- meutils/apis/translator/deeplx.py +55 -0
- meutils/apis/tripo3d/__init__.py +11 -0
- meutils/apis/tripo3d/images.py +106 -0
- meutils/apis/ts.py +60 -0
- meutils/apis/uptime_kuma/__init__.py +11 -0
- meutils/apis/uptime_kuma/common.py +56 -0
- meutils/apis/uptime_kuma//345/233/275/344/272/247/345/210/206/347/273/204.py +68 -0
- meutils/apis/utils.py +47 -0
- meutils/apis/videos/__init__.py +11 -0
- meutils/apis/videos/sora.py +16 -0
- meutils/apis/vidu/__init__.py +9 -0
- meutils/apis/vidu/vidu_video.py +254 -0
- meutils/apis/vidu/x.py +14 -0
- meutils/apis/voice_clone/__init__.py +10 -0
- meutils/apis/voice_clone/fish.py +236 -0
- meutils/apis/voice_clone/fish_api.py +16 -0
- meutils/apis/web_search.py +31 -0
- meutils/apis/yezi.py +97 -0
- meutils/async_task/__init__.py +13 -0
- meutils/async_task/celery_config.py +106 -0
- meutils/async_task/common.py +37 -0
- meutils/async_task/demo_create_tasks.py +73 -0
- meutils/async_task/tasks/__init__.py +11 -0
- meutils/async_task/tasks/_all.py +20 -0
- meutils/async_task/tasks/hailuo.py +24 -0
- meutils/async_task/tasks/kling.py +30 -0
- meutils/async_task/tasks/replicateai.py +24 -0
- meutils/async_task/tasks/test.py +124 -0
- meutils/async_task/tasks/vidu.py +28 -0
- meutils/async_task/utils.py +191 -0
- meutils/async_task//351/200/232/347/224/250/350/256/276/350/256/241.py +119 -0
- meutils/async_utils/asyncer_.py +37 -0
- meutils/async_utils/background.py +68 -0
- meutils/async_utils/common.py +136 -16
- meutils/async_utils/test.py +47 -0
- meutils/cache_utils.py +29 -23
- meutils/caches/__init__.py +9 -0
- meutils/caches/acache.py +45 -0
- meutils/caches/redis_cache.py +63 -0
- meutils/clis/check_api.py +66 -0
- meutils/clis/cli.py +1 -1
- meutils/common.py +56 -17
- meutils/config_utils/__init__.py +11 -0
- meutils/config_utils/lark_utils/__init__.py +11 -0
- meutils/config_utils/lark_utils/common.py +385 -0
- meutils/config_utils/lark_utils/demo.py +13 -0
- meutils/config_utils/lark_utils/x.py +50 -0
- meutils/config_utils/manager.py +108 -0
- meutils/crawlers/__init__.py +11 -0
- meutils/data/VERSION +1 -1
- meutils/data/cowboy-hat-face.webp +0 -0
- meutils/data/oneapi/FOOTER.md +7 -0
- meutils/data/oneapi/NOTICE.md +138 -0
- meutils/data/oneapi/__init__.py +15 -0
- meutils/db/orm.py +179 -0
- meutils/db/redis_db.py +87 -0
- meutils/decorators/cache.py +1 -1
- meutils/decorators/common.py +84 -5
- meutils/decorators/contextmanagers.py +17 -6
- meutils/decorators/fastapi_decorator.py +77 -3
- meutils/decorators/polling.py +46 -0
- meutils/decorators/retry.py +150 -26
- meutils/fastapi_utils/__init__.py +11 -0
- meutils/fastapi_utils/exceptions/http_error.py +72 -0
- meutils/fastapi_utils/exceptions/validation_error.py +44 -0
- meutils/hash_utils.py +9 -4
- meutils/hooks/__init__.py +11 -0
- meutils/hooks/hook_test.py +174 -0
- meutils/hooks/wechat.py +162 -0
- meutils/hooks/wechat_channel.py +303 -0
- meutils/init/evn.py +1 -1
- meutils/io/files_utils.py +232 -0
- meutils/io/image.py +148 -10
- meutils/io/x.py +75 -0
- meutils/llm/__init__.py +10 -0
- meutils/llm/check_api.py +109 -0
- meutils/llm/check_utils.py +106 -0
- meutils/llm/clients.py +38 -0
- meutils/llm/completions/__init__.py +11 -0
- meutils/llm/completions/agents/__init__.py +11 -0
- meutils/llm/completions/agents/file.py +125 -0
- meutils/llm/completions/cp.py +112 -0
- meutils/llm/completions/delilegal.py +135 -0
- meutils/llm/completions/dify.py +81 -0
- meutils/llm/completions/kimi.py +47 -0
- meutils/llm/completions/modelscope.py +11 -0
- meutils/{fileparser/filetype.py → llm/completions/oi.py} +5 -3
- meutils/llm/completions/rag/__init__.py +11 -0
- meutils/llm/completions/rag/fire.py +157 -0
- meutils/llm/completions/rag/qwen.py +11 -0
- meutils/llm/completions/rag/rag.py +41 -0
- meutils/llm/completions/rag.py +38 -0
- meutils/llm/completions/tryblend.py +201 -0
- meutils/llm/completions/tune.py +284 -0
- meutils/llm/completions/x.py +26 -0
- meutils/llm/completions/xx.py +61 -0
- meutils/llm/completions/yuanbao.py +176 -0
- meutils/llm/demo.py +114 -0
- meutils/llm/functions/__init__.py +11 -0
- meutils/llm/mappers.py +15 -0
- meutils/llm/openai_utils/__init__.py +11 -0
- meutils/llm/openai_utils/common.py +284 -0
- meutils/llm/openai_utils/tool_outputs.py +45 -0
- meutils/llm/output_parsers/__init__.py +80 -0
- meutils/llm/prompts/__init__.py +244 -0
- meutils/llm/prompts/demo.py +155 -0
- meutils/llm/prompts/html2image_test.py +19 -0
- meutils/llm/utils.py +133 -0
- meutils/llm/x.py +75 -0
- meutils/notice/feishu.py +40 -9
- meutils/notice/wechat.py +23 -21
- meutils/np_utils.py +10 -1
- meutils/office_automation/pdf.py +6 -1
- meutils/oss/__init__.py +20 -0
- meutils/oss/minio_oss.py +184 -0
- meutils/oss/minio_utils.py +48 -0
- meutils/other/__demo.py +6 -4
- meutils/pandas_utils/__init__.py +1 -0
- meutils/pandas_utils/common.py +31 -0
- meutils/pandas_utils/pd_utils.py +10 -6
- meutils/parsers/__init__.py +10 -0
- meutils/parsers/file_parsers.py +110 -0
- meutils/parsers/fileparser/demo.py +41 -0
- meutils/parsers/fileparser/filetype.py +41 -0
- meutils/pay.py +37 -0
- meutils/pipe.py +37 -4
- meutils/playwright_utils/common.py +20 -12
- meutils/plots/common.py +35 -34
- meutils/queues/demo.py +56 -0
- meutils/queues/smooth_queue.py +120 -0
- meutils/queues/uniform_queue.py +3 -1
- meutils/request_utils/__init__.py +26 -2
- meutils/request_utils/ark.py +47 -0
- meutils/request_utils/crawler.py +34 -5
- meutils/request_utils/jwt_utils/__init__.py +11 -0
- meutils/request_utils/jwt_utils/common.py +42 -0
- meutils/request_utils/volc.py +160 -0
- meutils/schemas/__init__.py +0 -1
- meutils/schemas/baidu_types.py +70 -0
- meutils/schemas/batch_types.py +450 -0
- meutils/schemas/celery_types.py +64 -0
- meutils/schemas/chatfire_types.py +15 -0
- meutils/schemas/chatglm_types.py +197 -0
- meutils/schemas/db/__init__.py +11 -0
- meutils/schemas/db/oneapi_types.py +117 -0
- meutils/schemas/dify_types.py +40 -0
- meutils/schemas/embedding.py +31 -0
- meutils/schemas/fal_types.py +13 -0
- meutils/schemas/fish_types.py +11 -0
- meutils/schemas/hailuo_types.py +208 -0
- meutils/schemas/haimian_types.py +51 -0
- meutils/schemas/idphoto_types.py +43 -0
- meutils/schemas/image_types.py +476 -0
- meutils/schemas/jimeng_types.py +28 -0
- meutils/schemas/jina_types.py +67 -0
- meutils/schemas/kimi_types.py +86 -0
- meutils/schemas/kling_types.py +235 -0
- meutils/schemas/kuaishou_types.py +328 -0
- meutils/schemas/luma_types.py +59 -0
- meutils/schemas/message_types.py +165 -0
- meutils/schemas/message_types_.py +219 -0
- meutils/schemas/metaso_types.py +64 -0
- meutils/schemas/napkin_types.py +85 -0
- meutils/schemas/ocr_types.py +37 -0
- meutils/schemas/oneapi/__init__.py +11 -0
- meutils/schemas/oneapi/_types.py +49 -0
- meutils/schemas/oneapi/common.py +883 -0
- meutils/schemas/oneapi/icons.py +30 -0
- meutils/schemas/oneapi/model_group_info.py +48 -0
- meutils/schemas/oneapi/model_info.py +34 -0
- meutils/schemas/oneapi/models.py +26 -0
- meutils/schemas/oneapi/x.py +26 -0
- meutils/schemas/oneapi//351/207/215/345/256/232/345/220/221.py +132 -0
- meutils/schemas/openai_api_protocol.py +411 -0
- meutils/schemas/openai_types.py +366 -0
- meutils/schemas/pixverse_types.py +88 -0
- meutils/schemas/playwright_types.py +57 -0
- meutils/schemas/prodia_types.py +19 -0
- meutils/schemas/replicate_types.py +112 -0
- meutils/schemas/request_types.py +20 -0
- meutils/schemas/runwayml_types.py +190 -0
- meutils/schemas/siliconflow_types.py +80 -0
- meutils/schemas/step_types.py +19 -0
- meutils/schemas/suno_types.py +319 -0
- meutils/schemas/task_types.py +192 -0
- meutils/schemas/translator_types.py +29 -0
- meutils/schemas/tripo3d_types.py +57 -0
- meutils/schemas/tryblend_types.py +51 -0
- meutils/schemas/video_types.py +62 -0
- meutils/schemas/vidu_types.py +350 -0
- meutils/schemas/wechat_types.py +316 -0
- meutils/schemas/yuanbao_types.py +260 -0
- meutils/serving/celery/__init__.py +8 -0
- meutils/serving/celery/config.py +115 -0
- meutils/serving/celery/router.py +4 -6
- meutils/serving/celery/tasks.py +6 -4
- meutils/serving/celery//351/200/232/347/224/250/350/256/276/350/256/241.py +119 -0
- meutils/serving/fastapi/common.py +27 -31
- meutils/serving/fastapi/dependencies/__init__.py +0 -1
- meutils/serving/fastapi/dependencies/auth.py +55 -2
- meutils/serving/fastapi/exceptions/http_error.py +67 -2
- meutils/serving/fastapi/exceptions/validation_error.py +18 -2
- meutils/serving/fastapi/lifespans.py +73 -0
- meutils/serving/fastapi/routers/scheduler.py +12 -0
- meutils/serving/fastapi/routers/screenshot.py +47 -0
- meutils/serving/fastapi/routers/spider.py +8 -3
- meutils/serving/fastapi/routers/task.py +48 -0
- meutils/serving/fastapi/utils.py +48 -1
- meutils/serving/streamlit/common.py +1 -1
- meutils/smooth_utils.py +3 -0
- meutils/str_utils/__init__.py +22 -3
- meutils/str_utils/json_utils.py +7 -0
- meutils/str_utils/regular_expression.py +102 -10
- meutils/templates/xx.html +21 -0
- meutils/templates/xxx.html +117 -0
- meutils/todo.py +12 -0
- meutils/tools/token_monitor.py +33 -0
- MeUtils-2024.3.4.13.4.45.dist-info/RECORD +0 -540
- meutils/ai_audio/asr/subtitle.srt +0 -40
- meutils/ai_audio/demo.ipynb +0 -1215
- meutils/ai_audio/example.srt +0 -348
- meutils/ai_audio/new.srt +0 -179
- meutils/ai_audio/subtitles.srt +0 -696
- meutils/ai_audio/tts/new.srt +0 -179
- meutils/ai_audio//350/247/206/351/242/221/345/220/210/345/271/266.sh +0 -32
- meutils/ai_cv/1.jpg +0 -0
- meutils/ai_cv/197.jpg +0 -0
- meutils/ai_cv/2.jpg +0 -0
- meutils/ai_cv/img.png +0 -0
- meutils/ai_cv/invoice.jpg +0 -0
- meutils/ai_cv/tbl.png +0 -0
- meutils/ai_cv/test.png +0 -0
- meutils/ann/README.md +0 -33
- meutils/ann/README_gensim.md +0 -47
- meutils/ann/examples/client.py +0 -59
- meutils/ann/examples/demo.py +0 -24
- meutils/api/deeplx.py +0 -29
- meutils/api/qr.png +0 -0
- meutils/clis/README.md +0 -29
- meutils/clis/__test.sh +0 -17
- meutils/clis/deepseek.txt +0 -8
- meutils/clis/deepseek_13003330042.json +0 -1
- meutils/clis/deepseek_13003872192.json +0 -1
- meutils/clis/deepseek_13852263862.json +0 -1
- meutils/clis/deepseek_13913898681.json +0 -1
- meutils/clis/deepseek_13962978617.json +0 -1
- meutils/clis/deepseek_15251801790.json +0 -1
- meutils/clis/deepseek_15720826383.json +0 -1
- meutils/clis/deepseek_18395563611.json +0 -1
- meutils/clis/deepseek_313303303@qq.com.json +0 -1
- meutils/clis/kimi_state.json +0 -1
- meutils/cmds/README.md +0 -55
- meutils/coding/__init__.py +0 -11
- meutils/coding/find132.py +0 -40
- meutils/db/README.md +0 -51
- meutils/decorators/README.md +0 -17
- meutils/docarray_utils/demo_es.py +0 -34
- meutils/docarray_utils/demo_hnsw.py +0 -55
- meutils/docarray_utils/in_memory.py +0 -38
- meutils/docarray_utils//346/224/271/351/200/240/344/270/213hnsw.py +0 -43
- meutils/io/file.py +0 -20
- meutils/io/img.png +0 -0
- meutils/io/x.yml +0 -1
- meutils/notice/img.png +0 -0
- meutils/notice/todo.md +0 -10
- meutils/office_automation//346/212/225/350/265/204/347/256/241/347/220/206/347/263/273/347/273/237O3.2_/344/272/244/346/230/223/347/273/204.pdm +0 -22469
- meutils/playwright_utils/__test.sh +0 -2
- meutils/playwright_utils/kimi1_cookies.json +0 -1
- meutils/playwright_utils/kimi2_cookies.json +0 -1
- meutils/playwright_utils/kimi_cookies.json +0 -93
- meutils/serving/README.md +0 -1
- meutils/serving/celery/_run.sh +0 -10
- meutils/serving/gui/run.sh +0 -9
- meutils/serving/jina/__demo/client.py +0 -42
- meutils/serving/jina/__demo/flow.svg +0 -1
- meutils/serving/jina/__demo/s.py +0 -34
- meutils/serving/jina/__demo/s2.py +0 -37
- meutils/serving/jina/__demo/server.py +0 -83
- meutils/serving/jina/__demo/test.py +0 -40
- meutils/serving/jina/executors/SentenceEncoder.py +0 -62
- meutils/serving/jina/executors/SentenceEncoder_.py +0 -63
- meutils/serving/jina/executors/__init__.py +0 -46
- meutils/serving/jina/executors/base.py +0 -40
- meutils/serving/jina/nlp_serving/__init__.py +0 -11
- meutils/serving/jina/nlp_serving/word_segmentation.py +0 -40
- meutils/serving/streamlit/conf.yaml +0 -5
- meutils/serving/streamlit/ocr.png +0 -0
- meutils/serving/streamlit/run.sh +0 -17
- meutils/serving/webui/.streamlit/_config.toml +0 -186
- meutils/serving/webui/.streamlit/config.toml +0 -26
- meutils/serving/webui/pages/_1_/345/210/206/350/257/215.py +0 -56
- meutils/serving/webui/pages/_2_/350/257/215/346/200/247/346/240/207/346/263/250/344/270/216/345/256/236/344/275/223/350/257/206/345/210/253.py +0 -54
- meutils/serving/webui/pages/_3_/346/226/207/346/234/254/345/214/271/351/205/215.py +0 -64
- meutils/serving/webui/run.sh +0 -9
- meutils/spark/__init__.py +0 -26
- meutils/tools/monitor.yml +0 -29
- {MeUtils-2024.3.4.13.4.45.dist-info → MeUtils-2025.1.16.17.15.52.dist-info}/LICENSE +0 -0
- {MeUtils-2024.3.4.13.4.45.dist-info → MeUtils-2025.1.16.17.15.52.dist-info}/top_level.txt +0 -0
- {meutils → examples}/comp_utils/__init__.py +0 -0
- {meutils → examples}/comp_utils/reverse_metric.py +0 -0
- /meutils/{fileparser/README.md → fastapi_utils/exceptions/__init__.py} +0 -0
- /meutils/{fileparser → parsers/fileparser}/PDF/346/212/275/345/217/226.py" +0 -0
- /meutils/{fileparser → parsers/fileparser}/__init__.py +0 -0
- /meutils/{fileparser → parsers/fileparser}/common.py +0 -0
- /meutils/{fileparser → parsers/fileparser}/filetype/__init__.py +0 -0
- /meutils/{fileparser → parsers/fileparser}/filetype/__main__.py +0 -0
- /meutils/{fileparser → parsers/fileparser}/filetype/filetype.py +0 -0
- /meutils/{fileparser → parsers/fileparser}/filetype/helpers.py +0 -0
- /meutils/{fileparser → parsers/fileparser}/filetype/match.py +0 -0
- /meutils/{fileparser → parsers/fileparser}/filetype/types/__init__.py +0 -0
- /meutils/{fileparser → parsers/fileparser}/filetype/types/application.py +0 -0
- /meutils/{fileparser → parsers/fileparser}/filetype/types/archive.py +0 -0
- /meutils/{fileparser → parsers/fileparser}/filetype/types/audio.py +0 -0
- /meutils/{fileparser → parsers/fileparser}/filetype/types/base.py +0 -0
- /meutils/{fileparser → parsers/fileparser}/filetype/types/document.py +0 -0
- /meutils/{fileparser → parsers/fileparser}/filetype/types/font.py +0 -0
- /meutils/{fileparser → parsers/fileparser}/filetype/types/image.py +0 -0
- /meutils/{fileparser → parsers/fileparser}/filetype/types/isobmff.py +0 -0
- /meutils/{fileparser → parsers/fileparser}/filetype/types/video.py +0 -0
- /meutils/{fileparser → parsers/fileparser}/filetype/utils.py +0 -0
- /meutils/{fileparser → parsers/fileparser}/pdf.py +0 -0
- /meutils/{fileparser → parsers/fileparser}//350/241/250/346/240/274/346/212/275/345/217/226.py" +0 -0
@@ -0,0 +1,13 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : __init__.py
|
5
|
+
# @Time : 2024/11/28 15:28
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description :
|
10
|
+
|
11
|
+
|
12
|
+
# from meutils.async_task.common import worker, shared_task, AsyncResult, states
|
13
|
+
from meutils.async_task.common import *
|
@@ -0,0 +1,106 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : config
|
5
|
+
# @Time : 2024/11/28 14:47
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description :
|
10
|
+
|
11
|
+
from meutils.pipe import *
|
12
|
+
from datetime import timedelta
|
13
|
+
from kombu import Exchange, Queue
|
14
|
+
|
15
|
+
# 基础配置
|
16
|
+
broker_url = 'redis://localhost:6379/0' # 消息代理(推荐使用Redis)
|
17
|
+
broker_url = os.getenv('REDIS_URL', broker_url)
|
18
|
+
|
19
|
+
# result_backend = f"redis://localhost:6379/1" # 结果存储
|
20
|
+
result_backend = f"{broker_url.replace('/0', '')}/1" # 结果存储
|
21
|
+
|
22
|
+
# logger.debug(result_backend)
|
23
|
+
|
24
|
+
# 添加以下配置增加可靠性
|
25
|
+
broker_connection_retry = True
|
26
|
+
broker_connection_max_retries = 5
|
27
|
+
broker_connection_retry_on_startup = True
|
28
|
+
|
29
|
+
# 时区设置
|
30
|
+
enable_utc = False
|
31
|
+
timezone = 'Asia/Shanghai'
|
32
|
+
|
33
|
+
# 任务序列化与反序列化配置
|
34
|
+
task_serializer = 'json'
|
35
|
+
result_serializer = 'json'
|
36
|
+
accept_content = ['json']
|
37
|
+
|
38
|
+
# 并发配置
|
39
|
+
# worker_pool = 'solo' # 工作进程池类型,可选:'prefork'、'eventlet'、'gevent'
|
40
|
+
worker_pool_restarts = True
|
41
|
+
worker_concurrency = 8 # worker并发数,一般设置为CPU核心数
|
42
|
+
worker_prefetch_multiplier = 3 # 预取任务数
|
43
|
+
worker_max_tasks_per_child = 256 # 每个worker执行多少个任务后自动重启
|
44
|
+
|
45
|
+
# 任务队列配置
|
46
|
+
task_default_queue = 'default' # 默认队列
|
47
|
+
task_queues = (
|
48
|
+
Queue('default', Exchange('default'), routing_key='default'),
|
49
|
+
Queue('high_priority', Exchange('high_priority'), routing_key='high_priority'),
|
50
|
+
Queue('low_priority', Exchange('low_priority'), routing_key='low_priority'),
|
51
|
+
)
|
52
|
+
|
53
|
+
# 任务执行设置
|
54
|
+
task_soft_time_limit = 10 * 60 # 任务软超时时间(秒)
|
55
|
+
task_time_limit = 2 * task_soft_time_limit # 任务硬超时时间(秒)
|
56
|
+
|
57
|
+
# 任务重试配置
|
58
|
+
task_publish_retry = True # 发布任务失败时重试
|
59
|
+
task_publish_retry_policy = {
|
60
|
+
'max_retries': 5, # 最大重试次数
|
61
|
+
'interval_start': 0, # 初始重试等待时间
|
62
|
+
'interval_step': 2, # 重试间隔递增步长
|
63
|
+
'interval_max': 16, # 最大重试间隔
|
64
|
+
}
|
65
|
+
|
66
|
+
# # 任务路由配置
|
67
|
+
# task_routes = {
|
68
|
+
# 'project.tasks.high_priority_task': {'queue': 'high_priority'},
|
69
|
+
# 'project.tasks.low_priority_task': {'queue': 'low_priority'},
|
70
|
+
# }
|
71
|
+
#
|
72
|
+
# # 定时任务配置
|
73
|
+
# beat_schedule = {
|
74
|
+
# 'task-every-30-seconds': {
|
75
|
+
# 'task': 'project.tasks.periodic_task',
|
76
|
+
# 'schedule': timedelta(seconds=30),
|
77
|
+
# },
|
78
|
+
# }
|
79
|
+
|
80
|
+
# 日志配置
|
81
|
+
worker_log_format = '[%(asctime)s: %(levelname)s/%(processName)s] %(message)s'
|
82
|
+
worker_task_log_format = '[%(asctime)s: %(levelname)s/%(processName)s] [%(task_name)s(%(task_id)s)] %(message)s'
|
83
|
+
|
84
|
+
# 性能优化
|
85
|
+
task_acks_late = True # 任务执行完成后再确认
|
86
|
+
task_reject_on_worker_lost = True # worker异常关闭时任务会被重新分配
|
87
|
+
worker_disable_rate_limits = True # 禁用任务频率限制
|
88
|
+
|
89
|
+
# 结果后端配置
|
90
|
+
result_expires = 30 * 24 * 3600 # 结果过期时间(秒)
|
91
|
+
result_persistent = True # 结果持久化存储
|
92
|
+
|
93
|
+
# 任务执行配置
|
94
|
+
# task_always_eager = False # 是否立即执行任务(调试用)
|
95
|
+
|
96
|
+
# 添加任务持久化配置
|
97
|
+
celery_task_store_errors_even_if_ignored = True
|
98
|
+
celery_task_ignore_result = False # 不忽略结果
|
99
|
+
celery_task_track_started = True # 跟踪任务状态
|
100
|
+
|
101
|
+
# Redis 持久化配置
|
102
|
+
broker_transport_options = {
|
103
|
+
'visibility_timeout': 43200, # 12小时
|
104
|
+
'fanout_prefix': True,
|
105
|
+
'fanout_patterns': True,
|
106
|
+
}
|
@@ -0,0 +1,37 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : common
|
5
|
+
# @Time : 2024/11/28 15:28
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description :
|
10
|
+
|
11
|
+
from meutils.pipe import *
|
12
|
+
from meutils.decorators.retry import retrying
|
13
|
+
|
14
|
+
from meutils.async_task import celery_config
|
15
|
+
|
16
|
+
from celery import Celery, Task, shared_task, states
|
17
|
+
|
18
|
+
|
19
|
+
|
20
|
+
worker = Celery()
|
21
|
+
|
22
|
+
worker.config_from_object(celery_config)
|
23
|
+
|
24
|
+
worker.conf.update(
|
25
|
+
# result_expires=30 * 24 * 60 * 60,
|
26
|
+
# enable_utc=False,
|
27
|
+
# timezone='Asia/Shanghai',
|
28
|
+
task_track_started=True,
|
29
|
+
)
|
30
|
+
|
31
|
+
if __name__ == '__main__':
|
32
|
+
print(worker.conf.humanize(with_defaults=False))
|
33
|
+
|
34
|
+
print(worker.conf.broker_url)
|
35
|
+
print(worker.conf.result_backend)
|
36
|
+
|
37
|
+
print(arun(get_task("59ddf636-3f27-4110-948e-5977c8cbe1b3")))
|
@@ -0,0 +1,73 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : x
|
5
|
+
# @Time : 2024/11/28 15:42
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description :
|
10
|
+
|
11
|
+
from meutils.pipe import *
|
12
|
+
|
13
|
+
from meutils.async_task import worker
|
14
|
+
from meutils.async_task.tasks import test, kling, hailuo
|
15
|
+
from celery.result import AsyncResult
|
16
|
+
|
17
|
+
# print(worker.conf)
|
18
|
+
|
19
|
+
# @shared_task(
|
20
|
+
# autoretry_for=(Exception,), # 自动重试的异常类型
|
21
|
+
# retry_kwargs={
|
22
|
+
# 'max_retries': 3, # 最大重试次数
|
23
|
+
# 'countdown': 60 # 重试等待时间(秒)
|
24
|
+
# },
|
25
|
+
# retry_backoff=True, # 启用指数退避
|
26
|
+
# retry_backoff_max=600, # 最大退避时间(秒)
|
27
|
+
# retry_jitter=True # 添加随机抖动
|
28
|
+
# )
|
29
|
+
# def my_task():
|
30
|
+
# try:
|
31
|
+
# # 任务逻辑
|
32
|
+
# result = some_operation()
|
33
|
+
# return result
|
34
|
+
# except Exception as exc:
|
35
|
+
# logger.error(f"Task failed: {exc}")
|
36
|
+
# raise # 触发自动重试
|
37
|
+
|
38
|
+
|
39
|
+
if __name__ == '__main__':
|
40
|
+
# r = test.do_sync_task.apply_async(kwargs={'a': 1, 'b': 2})
|
41
|
+
# logger.debug(r.backend)
|
42
|
+
# test.ado_sync_task.apply_async(kwargs={'a': 1, 'b': 2})
|
43
|
+
# test.ado_sync_task.apply_async(kwargs={'a': 1, 'b': 3})
|
44
|
+
# print(AsyncResult("42e191a0-6099-419e-b61d-07bf7e2df2fc").result)
|
45
|
+
# result.backend
|
46
|
+
# AsyncResult("42e191a0-6099-419e-b61d-07bf7e2df2fc").get()
|
47
|
+
# AsyncResult(r.id).result
|
48
|
+
|
49
|
+
# test.do_pydantic_task.apply_async(kwargs={'request': test.Request()})
|
50
|
+
|
51
|
+
# test.do_pydantic_task.apply_async(kwargs={"request": {"method": "POST", "url": "测试"}})
|
52
|
+
|
53
|
+
# print(type(test.do_pydantic_task))
|
54
|
+
|
55
|
+
# test.do_pydantic_task.apply_async(kwargs={"request": {"method": "POST", "url": "测试"}})
|
56
|
+
# test.do_pydantic_task.apply_async(kwargs={"request": {"method": "xx"}})
|
57
|
+
# test.do_pydantic_task.apply_async(args=({"method": "xxxxxxx"},))
|
58
|
+
|
59
|
+
#
|
60
|
+
# test.do_task_retrying.apply_async(kwargs={'name': "###do_task_retrying"})
|
61
|
+
# test.do_task_retry.apply_async(kwargs={'name': "###do_task_retry"})
|
62
|
+
# test.do_task_retry_backoff.apply_async(kwargs={'name': "###do_task_retry_backoff"})
|
63
|
+
# test.ado_pydantic_task.apply_async(kwargs={'name': "###do_task_retry_backoff"})
|
64
|
+
|
65
|
+
test.Request()
|
66
|
+
# test.ado_pydantic_task.apply_async(kwargs={"request": None})
|
67
|
+
|
68
|
+
# test.ado_pydantic_task.apply_async(kwargs={"request": test.Request().model_dump()})
|
69
|
+
# test.ado_pydantic_task_2.apply_async(kwargs={"request": test.Request().model_dump()})
|
70
|
+
|
71
|
+
# kling.create_task.apply_async(kwargs={"request": kling.kolors_virtual_try_on.TryOnRequest().model_dump()})
|
72
|
+
|
73
|
+
hailuo.create_task.apply_async(kwargs={"request": hailuo.VideoRequest(prompt='a dog').model_dump()})
|
@@ -0,0 +1,20 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : all_tasks
|
5
|
+
# @Time : 2024/11/28 17:50
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description :
|
10
|
+
|
11
|
+
|
12
|
+
# 所有异步任务
|
13
|
+
from meutils.pipe import *
|
14
|
+
from meutils.async_task import worker
|
15
|
+
|
16
|
+
for p in get_resolve_path('.', __file__).glob('*'):
|
17
|
+
|
18
|
+
if (not p.name.startswith('_')) and p.name.endswith('.py'):
|
19
|
+
logger.debug(p)
|
20
|
+
_ = try_import(f"meutils.async_task.tasks.{p.stem}")
|
@@ -0,0 +1,24 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : hailuo
|
5
|
+
# @Time : 2024/12/6 09:05
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description :
|
10
|
+
|
11
|
+
|
12
|
+
from meutils.async_utils import async_to_sync_pro
|
13
|
+
from meutils.async_task import worker, shared_task
|
14
|
+
from meutils.apis.hailuoai.videos import VideoRequest, create_task as remote_create_task, get_task
|
15
|
+
|
16
|
+
|
17
|
+
@shared_task(pydantic=True, retry_kwargs={'max_retries': 10, 'countdown': 10})
|
18
|
+
@async_to_sync_pro
|
19
|
+
async def create_task(request, **kwargs):
|
20
|
+
if isinstance(request, dict):
|
21
|
+
request = VideoRequest(**request)
|
22
|
+
|
23
|
+
response = await remote_create_task(request)
|
24
|
+
return response.model_dump()
|
@@ -0,0 +1,30 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : kling
|
5
|
+
# @Time : 2024/11/28 16:18
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description : 注册任务
|
10
|
+
|
11
|
+
from meutils.async_utils import async_to_sync_pro
|
12
|
+
from meutils.async_task import worker, shared_task
|
13
|
+
|
14
|
+
from meutils.apis.kling import kolors_virtual_try_on
|
15
|
+
|
16
|
+
|
17
|
+
@shared_task(pydantic=True, retry_kwargs={'max_retries': 5, 'countdown': 10})
|
18
|
+
@async_to_sync_pro
|
19
|
+
async def create_task(request: kolors_virtual_try_on.TryOnRequest, **kwargs):
|
20
|
+
if isinstance(request, dict):
|
21
|
+
request = kolors_virtual_try_on.TryOnRequest(**request)
|
22
|
+
|
23
|
+
response = await kolors_virtual_try_on.create_task(request)
|
24
|
+
return response.model_dump()
|
25
|
+
|
26
|
+
|
27
|
+
if __name__ == '__main__':
|
28
|
+
pass
|
29
|
+
# create_task.apply_async()
|
30
|
+
create_task.apply_async(kwargs={"request": kolors_virtual_try_on.TryOnRequest().model_dump()})
|
@@ -0,0 +1,24 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : replicateai
|
5
|
+
# @Time : 2024/11/29 19:08
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description :
|
10
|
+
|
11
|
+
|
12
|
+
from meutils.pipe import *
|
13
|
+
from meutils.async_utils import async_to_sync_pro
|
14
|
+
from meutils.decorators.retry import retrying
|
15
|
+
from meutils.async_task import worker, shared_task
|
16
|
+
|
17
|
+
from meutils.apis.replicateai import raw as replicate
|
18
|
+
|
19
|
+
|
20
|
+
@shared_task(pydantic=True, retry_kwargs={'max_retries': 5, 'countdown': 10})
|
21
|
+
@async_to_sync_pro
|
22
|
+
async def create_task(request: replicate.ReplicateRequest, **kwargs):
|
23
|
+
response = await replicate.create_task(request)
|
24
|
+
return response
|
@@ -0,0 +1,124 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : kling
|
5
|
+
# @Time : 2024/11/28 16:18
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description :
|
10
|
+
|
11
|
+
from meutils.pipe import *
|
12
|
+
from meutils.decorators.retry import retrying
|
13
|
+
from meutils.async_utils import async_to_sync_pro
|
14
|
+
from meutils.async_task import worker, shared_task
|
15
|
+
|
16
|
+
|
17
|
+
class Request(BaseModel):
|
18
|
+
method: str = "GET"
|
19
|
+
url: str = "https://api.chatfire.cn/"
|
20
|
+
|
21
|
+
class Config:
|
22
|
+
frozen = True
|
23
|
+
|
24
|
+
|
25
|
+
@shared_task
|
26
|
+
def do_sync_task(sleep=10, **kwargs):
|
27
|
+
logger.debug("同步任务")
|
28
|
+
time.sleep(sleep)
|
29
|
+
|
30
|
+
return kwargs
|
31
|
+
|
32
|
+
|
33
|
+
# AttributeError: 'AsyncToSync' object has no attribute '__name__'. Did you mean: '__ne__'?
|
34
|
+
|
35
|
+
|
36
|
+
@alru_cache()
|
37
|
+
async def create_task(request: Request, **kwargs):
|
38
|
+
logger.debug(request)
|
39
|
+
await asyncio.sleep(10)
|
40
|
+
return request
|
41
|
+
|
42
|
+
|
43
|
+
worker.task()
|
44
|
+
|
45
|
+
|
46
|
+
@shared_task(pydantic=True)
|
47
|
+
@async_to_sync_pro
|
48
|
+
async def ado_pydantic_task(request: Request):
|
49
|
+
logger.debug("同步任务+协程+结构体+缓存")
|
50
|
+
logger.debug(request)
|
51
|
+
if isinstance(request, dict):
|
52
|
+
request = Request(**request)
|
53
|
+
|
54
|
+
return await create_task(request)
|
55
|
+
|
56
|
+
|
57
|
+
@worker.task(pydantic=True)
|
58
|
+
@async_to_sync_pro
|
59
|
+
async def ado_pydantic_task_2(request: Request):
|
60
|
+
logger.debug("同步任务+协程+结构体+缓存")
|
61
|
+
logger.debug(request)
|
62
|
+
|
63
|
+
return await create_task(request)
|
64
|
+
|
65
|
+
|
66
|
+
@shared_task(pydantic=True)
|
67
|
+
def do_pydantic_task(request: Request) -> Request:
|
68
|
+
logger.debug(request)
|
69
|
+
return request
|
70
|
+
|
71
|
+
|
72
|
+
@shared_task(retry_kwargs={'max_retries': 10})
|
73
|
+
def do_task_retry(*args, **kwargs):
|
74
|
+
logger.debug("do_task_retry")
|
75
|
+
|
76
|
+
return 1 / 0
|
77
|
+
|
78
|
+
|
79
|
+
@shared_task(
|
80
|
+
default_retry_delay=3,
|
81
|
+
retry_backoff=True,
|
82
|
+
retry_kwargs={'max_retries': 10}
|
83
|
+
)
|
84
|
+
def do_task_retry_backoff_noautoretry(*args, **kwargs):
|
85
|
+
logger.debug("do_task_retry_backoff")
|
86
|
+
|
87
|
+
return 1 / 0
|
88
|
+
|
89
|
+
|
90
|
+
@shared_task(
|
91
|
+
autoretry_for=(Exception,),
|
92
|
+
default_retry_delay=3,
|
93
|
+
retry_backoff=True,
|
94
|
+
retry_kwargs={'max_retries': 10}
|
95
|
+
)
|
96
|
+
def do_task_retry_backoff(*args, **kwargs):
|
97
|
+
logger.debug("do_task_retry_backoff autoretry")
|
98
|
+
|
99
|
+
return 1 / 0
|
100
|
+
|
101
|
+
|
102
|
+
@shared_task(retry_kwargs={'max_retries': 3})
|
103
|
+
@retrying(10)
|
104
|
+
def do_task_retrying(*args, **kwargs):
|
105
|
+
logger.debug("do_task_retrying")
|
106
|
+
return 1 / 0
|
107
|
+
|
108
|
+
|
109
|
+
@shared_task
|
110
|
+
@retrying(3)
|
111
|
+
def proxy_task(**kwargs):
|
112
|
+
method = kwargs.pop('method', '')
|
113
|
+
url = kwargs.pop('url', '')
|
114
|
+
|
115
|
+
logger.debug(kwargs)
|
116
|
+
|
117
|
+
response = requests.request(method, url, **kwargs).json()
|
118
|
+
|
119
|
+
return response
|
120
|
+
|
121
|
+
|
122
|
+
if __name__ == '__main__':
|
123
|
+
# print(do_sync_task.apply_async(kwargs={'a': 1, 'b': 2}))
|
124
|
+
print(AsyncToSync)
|
@@ -0,0 +1,28 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : kling
|
5
|
+
# @Time : 2024/11/28 16:18
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description :
|
10
|
+
|
11
|
+
from meutils.pipe import *
|
12
|
+
from meutils.decorators.retry import retrying
|
13
|
+
from meutils.async_task import worker, shared_task
|
14
|
+
|
15
|
+
from meutils.apis.vidu.vidu_video import create_task, get_task, ViduRequest
|
16
|
+
|
17
|
+
|
18
|
+
@shared_task
|
19
|
+
async def do_task(**kwargs):
|
20
|
+
return create_task(ViduRequest(**kwargs))
|
21
|
+
|
22
|
+
|
23
|
+
@shared_task
|
24
|
+
@retrying(3)
|
25
|
+
async def proxy_task(**kwargs):
|
26
|
+
pass
|
27
|
+
|
28
|
+
return response
|
@@ -0,0 +1,191 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : utils
|
5
|
+
# @Time : 2024/11/29 16:22
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description : 通用异步设计,兼容oneapi监控
|
10
|
+
|
11
|
+
from celery.result import AsyncResult
|
12
|
+
|
13
|
+
from meutils.pipe import *
|
14
|
+
from meutils.schemas.task_types import TaskResponse
|
15
|
+
|
16
|
+
from meutils.db.orm import update_or_insert
|
17
|
+
from meutils.schemas.db.oneapi_types import OneapiTask
|
18
|
+
|
19
|
+
from meutils.db.redis_db import redis_aclient
|
20
|
+
|
21
|
+
from fastapi import APIRouter, File, UploadFile, Query, Form, Depends, Request, HTTPException, status, BackgroundTasks
|
22
|
+
|
23
|
+
|
24
|
+
async def create_task(async_task, request: Union[BaseModel, dict]):
|
25
|
+
if not isinstance(request, dict):
|
26
|
+
request = request.model_dump()
|
27
|
+
|
28
|
+
result = async_task.apply_async(kwargs={"request": request})
|
29
|
+
task_id = result.id
|
30
|
+
|
31
|
+
return TaskResponse(task_id=task_id, request_id=task_id)
|
32
|
+
|
33
|
+
|
34
|
+
# {
|
35
|
+
# "code": 0,
|
36
|
+
# "message": "SUCCEED",
|
37
|
+
# "request_id": "CjMkWmdJhuIAAAAAAAS0mA",
|
38
|
+
# "data": {
|
39
|
+
# "task_id": "CjMkWmdJhuIAAAAAAAS0mA",
|
40
|
+
# "task_status": "submitted",
|
41
|
+
# "created_at": 1732881630997,
|
42
|
+
# "updated_at": 1732881630997
|
43
|
+
# }
|
44
|
+
# }
|
45
|
+
|
46
|
+
|
47
|
+
async def get_task(
|
48
|
+
task_id: str,
|
49
|
+
remote_get_task: Optional[Callable] = None,
|
50
|
+
filter_kwargs: Optional[dict] = None,
|
51
|
+
background_tasks: Optional[BackgroundTasks] = None,
|
52
|
+
):
|
53
|
+
"""
|
54
|
+
|
55
|
+
:param task_id:
|
56
|
+
:param remote_get_task:
|
57
|
+
:param filter_kwargs: #######参数可以舍弃
|
58
|
+
filter_kwargs = {
|
59
|
+
"task_id": task_id, #########理论上只需这个
|
60
|
+
"user_id": user_id,
|
61
|
+
"platform": "replicate",
|
62
|
+
"action": "replicate", # 模型
|
63
|
+
}
|
64
|
+
:return:
|
65
|
+
"""
|
66
|
+
filter_kwargs = filter_kwargs or {}
|
67
|
+
filter_kwargs["task_id"] = task_id
|
68
|
+
|
69
|
+
result = AsyncResult(id=task_id)
|
70
|
+
logger.debug(bjson(result._get_task_meta()))
|
71
|
+
# logger.debug(bjson(result.get(timeout=30)))
|
72
|
+
logger.debug(result)
|
73
|
+
logger.debug(result.ready())
|
74
|
+
logger.debug(result.state)
|
75
|
+
|
76
|
+
# if result.status=="PENDING": # worker可能还未启动,会阻塞
|
77
|
+
# if await redis_aclient.select(1) and not await redis_aclient.exists(f"celery-task-meta-{task_id}"):
|
78
|
+
# raise HTTPException(status_code=404, detail="TaskID not found")
|
79
|
+
|
80
|
+
if result.ready():
|
81
|
+
if result.successful():
|
82
|
+
data = result.get(timeout=30).copy() # 创建任务时:remote task的返回结果 ####### copy避免丢失字段
|
83
|
+
logger.debug(bjson(data))
|
84
|
+
token = data.pop("system_fingerprint", None) # 远程任务 token/apikey
|
85
|
+
|
86
|
+
remote_task_id = (
|
87
|
+
data.get("task_id") # 提前写
|
88
|
+
or data.get("data", {}).get("task_id")
|
89
|
+
or data.get("data", {}).get("id")
|
90
|
+
or data.get("id")
|
91
|
+
or data.get("request_id")
|
92
|
+
)
|
93
|
+
|
94
|
+
response = TaskResponse(
|
95
|
+
task_id=task_id,
|
96
|
+
|
97
|
+
message="Task completed successfully",
|
98
|
+
status=result.status,
|
99
|
+
data=data
|
100
|
+
)
|
101
|
+
|
102
|
+
if remote_get_task:
|
103
|
+
if inspect.iscoroutinefunction(remote_get_task):
|
104
|
+
remote_task_response = await remote_get_task(remote_task_id, token)
|
105
|
+
else:
|
106
|
+
remote_task_response = remote_get_task(remote_task_id, token)
|
107
|
+
|
108
|
+
if not isinstance(remote_task_response, dict):
|
109
|
+
remote_task_response = remote_task_response.model_dump()
|
110
|
+
|
111
|
+
# logger.debug(response.model_dump_json(indent=4))
|
112
|
+
# logger.debug(bjson(remote_task_response))
|
113
|
+
|
114
|
+
_response = {**response.model_dump(), **remote_task_response}
|
115
|
+
response = response.construct(**_response)
|
116
|
+
|
117
|
+
# logger.debug(response.model_dump_json(indent=4))
|
118
|
+
|
119
|
+
else:
|
120
|
+
response = TaskResponse(
|
121
|
+
task_id=task_id,
|
122
|
+
|
123
|
+
code=1,
|
124
|
+
message=str(result.result),
|
125
|
+
status=result.status,
|
126
|
+
)
|
127
|
+
else:
|
128
|
+
response = TaskResponse(
|
129
|
+
task_id=task_id,
|
130
|
+
|
131
|
+
message="Task is still running",
|
132
|
+
status=result.status,
|
133
|
+
)
|
134
|
+
|
135
|
+
# 更新到数据库:异步任务
|
136
|
+
update_fn = partial(update_oneapi_from_response, task_response=response)
|
137
|
+
if background_tasks:
|
138
|
+
background_tasks.add_task(update_or_insert, OneapiTask, filter_kwargs, update_fn)
|
139
|
+
else:
|
140
|
+
await update_or_insert(OneapiTask, filter_kwargs, update_fn)
|
141
|
+
|
142
|
+
return response
|
143
|
+
|
144
|
+
|
145
|
+
# todo: 可以设计更通用的
|
146
|
+
async def update_oneapi_from_response(task: OneapiTask, task_response: TaskResponse):
|
147
|
+
"""
|
148
|
+
|
149
|
+
filter_kwargs = {
|
150
|
+
"task_id": task_id,
|
151
|
+
"user_id": user_id,
|
152
|
+
"platform": "replicate",
|
153
|
+
"action": "replicate", # 模型
|
154
|
+
}
|
155
|
+
|
156
|
+
需要获取这几个信息 user_id
|
157
|
+
|
158
|
+
"""
|
159
|
+
# if task.status in {"SUCCESS", "FAILURE"}: return False # 跳出轮询,不再更新
|
160
|
+
|
161
|
+
task.data = task_response.model_dump(exclude={"system_fingerprint"})
|
162
|
+
task.status = task_response.status
|
163
|
+
task.progress = time.time() // 10 % 100
|
164
|
+
|
165
|
+
if task.status == "SUCCESS": ###### todo: 状态对齐
|
166
|
+
task.progress = "100%"
|
167
|
+
elif task.status == "FAILURE":
|
168
|
+
task.fail_reason = "查看详情"
|
169
|
+
|
170
|
+
task.updated_at = int(time.time())
|
171
|
+
task.finish_time = int(time.time()) # 不是实际时间
|
172
|
+
|
173
|
+
|
174
|
+
if __name__ == '__main__':
|
175
|
+
from meutils.async_task import worker, shared_task #######重要 需要识别到worker
|
176
|
+
|
177
|
+
from meutils.apis.kling import kolors_virtual_try_on
|
178
|
+
from meutils.async_task.tasks import hailuo
|
179
|
+
|
180
|
+
task_id = "7d4fbaf3-f641-482b-b02c-ccd30e61195a"
|
181
|
+
# filter_kwargs = {
|
182
|
+
# "task_id": task_id, #########理论上只需这个
|
183
|
+
# "user_id": 1,
|
184
|
+
# "platform": "kling",
|
185
|
+
# "action": "kling", # 模型
|
186
|
+
# }
|
187
|
+
|
188
|
+
# arun(get_task(task_id, hailuo.get_task))
|
189
|
+
#
|
190
|
+
# task_id = "e3f76be8-f7eb-4562-a7af-029928d074d5"
|
191
|
+
# arun(get_task(task_id, kolors_virtual_try_on.get_task))
|