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,57 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : sql_creater
|
5
|
+
# @Time : 2024/11/18 20:45
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description :
|
10
|
+
import os
|
11
|
+
|
12
|
+
from meutils.pipe import *
|
13
|
+
from sqlalchemy import create_engine, inspect
|
14
|
+
from sqlmodel import SQLModel, Field, Integer, BigInteger, String
|
15
|
+
from typing import Optional
|
16
|
+
|
17
|
+
# 创建数据库连接
|
18
|
+
engine = create_engine(os.getenv("ONEAPI_SQL_URL"))
|
19
|
+
|
20
|
+
# 创建检查器
|
21
|
+
inspector = inspect(engine)
|
22
|
+
|
23
|
+
|
24
|
+
# 获取表的列信息
|
25
|
+
def get_table_columns(table_name):
|
26
|
+
columns = inspector.get_columns(table_name)
|
27
|
+
|
28
|
+
# 动态创建 SQLModel 类
|
29
|
+
class_attrs = {}
|
30
|
+
for column in columns:
|
31
|
+
column_name = column['name']
|
32
|
+
column_type = column['type']
|
33
|
+
nullable = column.get('nullable', True)
|
34
|
+
primary_key = column.get('primary_key', False)
|
35
|
+
|
36
|
+
# 根据不同的列类型选择合适的 Field
|
37
|
+
if primary_key:
|
38
|
+
field = Field(primary_key=True)
|
39
|
+
elif isinstance(column_type, (Integer, BigInteger)):
|
40
|
+
field = Field(default=None) if nullable else Field()
|
41
|
+
elif isinstance(column_type, String):
|
42
|
+
field = Field(default=None) if nullable else Field()
|
43
|
+
else:
|
44
|
+
field = Field()
|
45
|
+
|
46
|
+
class_attrs[column_name] = Optional[type(column_type)] if nullable else type(column_type)
|
47
|
+
class_attrs[f'{column_name}_field'] = field
|
48
|
+
|
49
|
+
# 动态创建 SQLModel 类
|
50
|
+
model_class = type(f'{table_name.capitalize()}Model', (SQLModel, BaseModel), class_attrs)
|
51
|
+
return model_class
|
52
|
+
|
53
|
+
|
54
|
+
|
55
|
+
if __name__ == '__main__':
|
56
|
+
# 使用示例
|
57
|
+
UserModel = get_table_columns('hero')
|
examples/orm/sqlm.py
ADDED
@@ -0,0 +1,134 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : sqlm
|
5
|
+
# @Time : 2024/11/18 19:54
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description : https://github.com/fastapi/sqlmodel/issues/543
|
10
|
+
# https://github.com/mastercoms/sqlmodel/blob/24d0307c49da2fea03f623f7e4d3f923398ac379/docs_src/tutorial_async/select_async/tutorial004_async.py
|
11
|
+
# 协程 https://github.com/deshetti/sqlmodel-async-example/blob/e412da00f557a352ee3f66a8545ef11401ea5dde/main.py#L42-L47
|
12
|
+
# https://github.com/deshetti/sqlmodel-async-example/blob/main/main.py
|
13
|
+
|
14
|
+
# https://github.com/google-marketing-solutions/Tightlock/blob/main/tightlock_api/app/db.py#L29
|
15
|
+
|
16
|
+
from meutils.pipe import *
|
17
|
+
|
18
|
+
from typing import Optional
|
19
|
+
|
20
|
+
from sqlmodel import Field, Session, SQLModel, create_engine, select
|
21
|
+
from sqlmodel.ext.asyncio.session import AsyncSession # 有点难
|
22
|
+
|
23
|
+
from sqlalchemy.ext.asyncio import create_async_engine
|
24
|
+
|
25
|
+
|
26
|
+
# from sqlalchemy.orm import sessionmaker
|
27
|
+
# from sqlmodel import create_engine
|
28
|
+
# from sqlmodel.ext.asyncio.session import AsyncEngine
|
29
|
+
# from sqlmodel.ext.asyncio.session import AsyncSession
|
30
|
+
#
|
31
|
+
# engine = AsyncEngine(create_engine(os.environ.get('CONFIG_DB_CONN'),
|
32
|
+
# echo=True, future=True))
|
33
|
+
#
|
34
|
+
#
|
35
|
+
# async def get_session() -> AsyncSession:
|
36
|
+
# async_session = sessionmaker(
|
37
|
+
# engine, class_=AsyncSession, expire_on_commit=False
|
38
|
+
# )
|
39
|
+
# async with async_session() as session:
|
40
|
+
# yield session
|
41
|
+
class Hero(SQLModel, table=True):
|
42
|
+
__table_args__ = {'extend_existing': True} # includes this line
|
43
|
+
|
44
|
+
id: Optional[int] = Field(default=None, primary_key=True)
|
45
|
+
name: str
|
46
|
+
secret_name: str
|
47
|
+
age: Optional[int] = None
|
48
|
+
|
49
|
+
|
50
|
+
hero_1 = Hero(name="Deadpond", secret_name="Dive Wilson")
|
51
|
+
hero_2 = Hero(name="Spider-Boy", secret_name="Pedro Parqueador")
|
52
|
+
hero_3 = Hero(name="Rusty-Man", secret_name="Tommy Sharp", age=48)
|
53
|
+
|
54
|
+
# engine = create_engine("sqlite:///database.db")
|
55
|
+
#
|
56
|
+
#
|
57
|
+
# SQLModel.metadata.create_all(engine)
|
58
|
+
#
|
59
|
+
# with Session(engine) as session:
|
60
|
+
# session.add(hero_1)
|
61
|
+
# session.add(hero_2)
|
62
|
+
# session.add(hero_3)
|
63
|
+
# session.commit()
|
64
|
+
###########################################################################直接这样也行
|
65
|
+
engine = create_async_engine("sqlite+aiosqlite:///:memory:")
|
66
|
+
|
67
|
+
|
68
|
+
async def get_db():
|
69
|
+
async with AsyncSession(engine) as session:
|
70
|
+
yield session
|
71
|
+
|
72
|
+
|
73
|
+
###########################################################################
|
74
|
+
|
75
|
+
if __name__ == '__main__':
|
76
|
+
from typing import Optional
|
77
|
+
|
78
|
+
from sqlmodel import Field, Session, SQLModel, create_engine, select
|
79
|
+
|
80
|
+
engine = create_engine("sqlite:///database.db")
|
81
|
+
|
82
|
+
with Session(engine) as session:
|
83
|
+
statement = select(Hero).where(Hero.name == "Spider-Boy")
|
84
|
+
hero = session.exec(statement).first()
|
85
|
+
print(hero)
|
86
|
+
|
87
|
+
aengine = create_async_engine("sqlite+aiosqlite:///:memory:")
|
88
|
+
|
89
|
+
|
90
|
+
async def main():
|
91
|
+
async with AsyncSession(engine) as session:
|
92
|
+
statement = select(Hero).where(Hero.name == "Spider-Boy")
|
93
|
+
hero = await session.exec(statement)
|
94
|
+
hero = hero.first()
|
95
|
+
print(hero)
|
96
|
+
|
97
|
+
|
98
|
+
arun(main())
|
99
|
+
|
100
|
+
# async def async_get_db() -> AsyncSession:
|
101
|
+
# async with async_session() as db:
|
102
|
+
# yield db
|
103
|
+
|
104
|
+
###########################################################################
|
105
|
+
from sqlmodel.ext.asyncio.session import AsyncSession
|
106
|
+
from sqlalchemy.orm import sessionmaker
|
107
|
+
|
108
|
+
... # rest of main.py
|
109
|
+
|
110
|
+
async def get_session() -> AsyncSession:
|
111
|
+
"""Dependency to provide the session object"""
|
112
|
+
async_session = sessionmaker(
|
113
|
+
bind=async_engine, class_=AsyncSession, expire_on_commit=False
|
114
|
+
)
|
115
|
+
|
116
|
+
async with async_session() as session:
|
117
|
+
yield session
|
118
|
+
|
119
|
+
###########################################################################
|
120
|
+
#########
|
121
|
+
# async_session = Session(engine, expire_on_commit=False, class_=AsyncSession)
|
122
|
+
#########
|
123
|
+
# async def get_async_session() -> AsyncGenerator[AsyncSession, None]:
|
124
|
+
# try:
|
125
|
+
# async_session = sessionmaker( # type: ignore
|
126
|
+
# bind=async_engine, class_=AsyncSession, expire_on_commit=False
|
127
|
+
# )
|
128
|
+
# async with async_session() as session:
|
129
|
+
# yield session
|
130
|
+
# except Exception:
|
131
|
+
# await session.rollback()
|
132
|
+
# raise
|
133
|
+
# finally:
|
134
|
+
# await session.close()
|
examples/rq_demo/fns.py
ADDED
@@ -0,0 +1,18 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : fns
|
5
|
+
# @Time : 2024/6/20 15:54
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description :
|
10
|
+
|
11
|
+
from meutils.pipe import *
|
12
|
+
|
13
|
+
from meutils.notice.feishu import send_message
|
14
|
+
|
15
|
+
|
16
|
+
def send(*args):
|
17
|
+
logger.debug(args)
|
18
|
+
return send_message(args)
|
@@ -10,15 +10,22 @@
|
|
10
10
|
import time
|
11
11
|
|
12
12
|
from meutils.pipe import *
|
13
|
-
from
|
14
|
-
from
|
13
|
+
from meutils.db.redis_db import redis_client
|
14
|
+
from meutils.notice.feishu import send_message
|
15
15
|
|
16
|
+
from rq import Queue
|
16
17
|
|
18
|
+
queue = Queue(connection=redis_client)
|
19
|
+
# queue = Queue(name='test', connection=redis_client)
|
17
20
|
|
21
|
+
# send_message('xxx')
|
22
|
+
task = queue.enqueue(
|
23
|
+
send_message,
|
24
|
+
content="xxx",
|
25
|
+
) # 通用函数
|
18
26
|
|
19
|
-
if __name__ == '__main__':
|
20
|
-
# Tell rq what Redis connection to use
|
21
|
-
with Connection():
|
22
|
-
q = Queue(connection=Redis())
|
23
27
|
|
24
|
-
|
28
|
+
task = queue.enqueue(
|
29
|
+
print,
|
30
|
+
"xxx",
|
31
|
+
) # 通用函数
|
@@ -0,0 +1,30 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : redis队列
|
5
|
+
# @Time : 2023/6/9 15:39
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description :
|
10
|
+
# from MeUtils.examples.redis队列 import queue
|
11
|
+
from meutils.pipe import *
|
12
|
+
from rq import Queue
|
13
|
+
from redis import Redis
|
14
|
+
|
15
|
+
from MeUtils.examples.demo import fn, fn666
|
16
|
+
from meutils.db.redis_db import redis_client
|
17
|
+
from meutils.serving.rq import rq_fn
|
18
|
+
|
19
|
+
queue = Queue(name='default', connection=redis_client)
|
20
|
+
|
21
|
+
task = queue.enqueue(rq_fn, time.time()) # 通用函数
|
22
|
+
task = queue.enqueue(fn, time.time()) # 通用函数
|
23
|
+
task = queue.enqueue(fn666, time.time()) # 通用函数
|
24
|
+
queue.enqueue
|
25
|
+
print("queue key", queue.key)
|
26
|
+
print("queue.jobs", len(queue.jobs))
|
27
|
+
|
28
|
+
time.sleep(3)
|
29
|
+
v = task.return_value()
|
30
|
+
print(type(v), v)
|
examples/size_map.py
ADDED
@@ -0,0 +1,43 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : size_map
|
5
|
+
# @Time : 2024/12/13 15:03
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description :
|
10
|
+
|
11
|
+
from meutils.pipe import *
|
12
|
+
|
13
|
+
|
14
|
+
def find_nearest_standard_size(width, height, standard_sizes):
|
15
|
+
"""
|
16
|
+
找到最接近的标准尺寸
|
17
|
+
standard_sizes: 标准尺寸列表,如 [(256,256), (512,512), ...]
|
18
|
+
"""
|
19
|
+
min_diff = float('inf')
|
20
|
+
nearest_size = None
|
21
|
+
|
22
|
+
for std_width, std_height in standard_sizes:
|
23
|
+
diff = abs(width - std_width) + abs(height - std_height)
|
24
|
+
if diff < min_diff:
|
25
|
+
min_diff = diff
|
26
|
+
nearest_size = (std_width, std_height)
|
27
|
+
|
28
|
+
return nearest_size
|
29
|
+
|
30
|
+
|
31
|
+
# 标准尺寸列表
|
32
|
+
standard_sizes = [
|
33
|
+
(256, 256),
|
34
|
+
(512, 512),
|
35
|
+
(1024, 1024),
|
36
|
+
(1792, 1024),
|
37
|
+
(1024, 1792)
|
38
|
+
]
|
39
|
+
|
40
|
+
# 使用示例
|
41
|
+
width, height = 600, 600
|
42
|
+
nearest = find_nearest_standard_size(width, height, standard_sizes)
|
43
|
+
print(f"最接近 {width}x{height} 的标准尺寸是: {nearest}")
|
examples/test.py
ADDED
@@ -0,0 +1,59 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : test
|
5
|
+
# @Time : 2024/6/11 11:58
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description :
|
10
|
+
import time
|
11
|
+
import typing
|
12
|
+
|
13
|
+
from meutils.pipe import *
|
14
|
+
from starlette.background import BackgroundTask as _BackgroundTask, BackgroundTasks as _BackgroundTasks
|
15
|
+
from asgiref.sync import async_to_sync
|
16
|
+
from meutils.decorators import background_task
|
17
|
+
|
18
|
+
|
19
|
+
class BackgroundTask(_BackgroundTask):
|
20
|
+
|
21
|
+
@background_task
|
22
|
+
def call(self):
|
23
|
+
async_to_sync(super().__call__)()
|
24
|
+
|
25
|
+
|
26
|
+
class BackgroundTasks(_BackgroundTasks):
|
27
|
+
|
28
|
+
@background_task
|
29
|
+
def call(self):
|
30
|
+
async_to_sync(super().__call__)()
|
31
|
+
|
32
|
+
|
33
|
+
async def f(x):
|
34
|
+
logger.debug(x)
|
35
|
+
|
36
|
+
for i in range(100):
|
37
|
+
logger.debug(i)
|
38
|
+
await asyncio.sleep(1)
|
39
|
+
|
40
|
+
|
41
|
+
BackgroundTask(f, x='xxxxxxxxxx').call()
|
42
|
+
|
43
|
+
# def f(x):
|
44
|
+
# logger.debug(x)
|
45
|
+
#
|
46
|
+
# for i in range(100):
|
47
|
+
# logger.debug(i)
|
48
|
+
# time.sleep(1)
|
49
|
+
|
50
|
+
|
51
|
+
# BackgroundTask(f, x='xxxxxxxxxx').call()
|
52
|
+
|
53
|
+
|
54
|
+
# bt = BackgroundTasks()
|
55
|
+
# bt.add_task(f, x='xxxxxxxxxx')
|
56
|
+
# bt.call()
|
57
|
+
print("#########")
|
58
|
+
# while 1:
|
59
|
+
# pass
|
examples/webs/main.py
ADDED
@@ -0,0 +1,34 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : main
|
5
|
+
# @Time : 2024/7/18 11:31
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description : https://google.github.io/mesop/demo/
|
10
|
+
|
11
|
+
from meutils.pipe import *
|
12
|
+
import time
|
13
|
+
|
14
|
+
import mesop as me
|
15
|
+
import mesop.labs as mel
|
16
|
+
me.stateclass
|
17
|
+
|
18
|
+
@me.page()
|
19
|
+
def app():
|
20
|
+
me.text("Hello World")
|
21
|
+
|
22
|
+
|
23
|
+
@me.page(path="/text_to_text", title="Text I/O Example")
|
24
|
+
def app():
|
25
|
+
mel.text_to_text(
|
26
|
+
upper_case_stream,
|
27
|
+
title="Text I/O Example",
|
28
|
+
)
|
29
|
+
|
30
|
+
|
31
|
+
def upper_case_stream(s: str):
|
32
|
+
yield s.capitalize()
|
33
|
+
time.sleep(0.5)
|
34
|
+
yield "Done"
|
examples/x.py
ADDED
@@ -0,0 +1,13 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : x
|
5
|
+
# @Time : 2024/11/25 15:29
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description :
|
10
|
+
|
11
|
+
from meutils.pipe import *
|
12
|
+
|
13
|
+
token = "a3db2416-f0f8-4087-9e82-1a52c52352e0"
|
@@ -0,0 +1,20 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : 去水印
|
5
|
+
# @Time : 2024/3/22 09:10
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description : https://www.jb51.net/article/278222.htm
|
10
|
+
|
11
|
+
from meutils.pipe import *
|
12
|
+
import poimage
|
13
|
+
|
14
|
+
# 支持jpg、png等所有图片格式
|
15
|
+
poimage.del_watermark(
|
16
|
+
input_image="img.png",
|
17
|
+
output_image='img_.png')
|
18
|
+
|
19
|
+
|
20
|
+
# https://h1.inkwai.com/bs2/upload-ylab-stunt/special-effect/output/HB1_PROD_ai_web_28605986/5266660862308034344/temp.png
|
meutils/_utils.py
CHANGED
@@ -10,13 +10,11 @@
|
|
10
10
|
|
11
11
|
import json
|
12
12
|
import base64
|
13
|
+
from pydantic import BaseModel
|
13
14
|
|
14
15
|
|
15
16
|
# bytes/string
|
16
17
|
|
17
|
-
def bytes2base64(bytes_data):
|
18
|
-
return base64.b64encode(bytes_data).decode()
|
19
|
-
|
20
18
|
|
21
19
|
# 列表
|
22
20
|
def list_replace(l, mapping=None):
|
@@ -42,8 +40,21 @@ def list_intersection(l1, l2):
|
|
42
40
|
|
43
41
|
list4log = lambda ls: "\n\t" + "\n\t".join(ls)
|
44
42
|
|
43
|
+
|
45
44
|
# 字典
|
46
|
-
|
45
|
+
|
46
|
+
|
47
|
+
def bjson(json_data):
|
48
|
+
if isinstance(json_data, dict):
|
49
|
+
return json.dumps(json_data, indent=4, ensure_ascii=False)
|
50
|
+
elif isinstance(json_data, BaseModel):
|
51
|
+
return json_data.model_dump_json(indent=4)
|
52
|
+
|
53
|
+
else:
|
54
|
+
return json_data
|
55
|
+
|
56
|
+
|
57
|
+
dict2json = bjson
|
47
58
|
json2dict = lambda s: json.loads(s.replace("'", '"'))
|
48
59
|
|
49
60
|
|
@@ -87,5 +98,3 @@ def dict_merge(dicts):
|
|
87
98
|
for k, v in d.items():
|
88
99
|
dic.setdefault(k, []).append(v)
|
89
100
|
return dic
|
90
|
-
|
91
|
-
|
meutils/ai_audio/asr/__init__.py
CHANGED
@@ -12,8 +12,9 @@ from meutils.pipe import *
|
|
12
12
|
|
13
13
|
from meutils.ai_audio.utils import to_audio
|
14
14
|
|
15
|
-
for p in Path('
|
16
|
-
to_audio(p, p.name.replace('mp3', 'pcm'), format="s16le", codec="pcm_s16le")
|
15
|
+
for p in Path('.').glob('*.mp3'):
|
16
|
+
# to_audio(p, p.name.replace('mp3', 'pcm'), format="s16le", codec="pcm_s16le")
|
17
|
+
to_audio(open("/Users/betterme/PycharmProjects/AI/MeUtils/meutils/ai_audio/asr/2022112519张健涛29.mp3", 'wb'), p, format="mp3")
|
17
18
|
|
18
19
|
# from pydub import AudioSegment
|
19
20
|
#
|
@@ -0,0 +1,53 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : cf_asr
|
5
|
+
# @Time : 2024/5/7 16:43
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description :
|
10
|
+
import httpx
|
11
|
+
|
12
|
+
from meutils.pipe import *
|
13
|
+
from meutils.str_utils import chinese_convert
|
14
|
+
|
15
|
+
# curl https://api.cloudflare.com/client/v4/accounts/$CLOUDFLARE_ACCOUNT_ID/ai/run/@cf/openai/whisper \
|
16
|
+
# -X POST \
|
17
|
+
# -H "Authorization: Bearer $CLOUDFLARE_API_TOKEN" \
|
18
|
+
# --data-binary "@talking-llama.mp3"
|
19
|
+
from fastapi import APIRouter, File, UploadFile, Query, Form, Depends, Request, HTTPException, status
|
20
|
+
|
21
|
+
|
22
|
+
cloudflare_account_id, api_key = os.getenv("CLOUDFLARE_API_TOKEN").split('-', maxsplit=1)
|
23
|
+
|
24
|
+
base_url = f"https://api.cloudflare.com/client/v4/accounts/{cloudflare_account_id}/ai/run"
|
25
|
+
|
26
|
+
headers = {"Authorization": f"Bearer {api_key}"}
|
27
|
+
|
28
|
+
httpx_client = httpx.Client(base_url=base_url, follow_redirects=True, timeout=100, headers=headers)
|
29
|
+
httpx_aclient = httpx.AsyncClient(base_url=base_url, follow_redirects=True, timeout=100, headers=headers)
|
30
|
+
|
31
|
+
file = open("f275d9ac-5a62-4bbe-baf9-3fa10e0332f4.mp3", 'rb')
|
32
|
+
payload = {"file": (file.name, file)}
|
33
|
+
#
|
34
|
+
# file = UploadFile(file)
|
35
|
+
# payload = {"file": (file.filename, file.file)}
|
36
|
+
#
|
37
|
+
# file = httpx.get("https://oss.chatfire.cn/data/demo.mp3").content
|
38
|
+
# payload = {"file": ('demo', file)}
|
39
|
+
|
40
|
+
|
41
|
+
|
42
|
+
|
43
|
+
# with timer('asr'):
|
44
|
+
# response = httpx_client.post("@cf/openai/whisper", files=payload)
|
45
|
+
# print(chinese_convert(bjson(response.json())))
|
46
|
+
|
47
|
+
if __name__ == '__main__':
|
48
|
+
async def asr():
|
49
|
+
response: httpx.Response = await httpx_aclient.post("@cf/openai/whisper", files=payload)
|
50
|
+
return response.json()
|
51
|
+
|
52
|
+
|
53
|
+
print(arun(asr()))
|
meutils/ai_audio/asr/fast_asr.py
CHANGED
@@ -6,7 +6,9 @@
|
|
6
6
|
# @Author : betterme
|
7
7
|
# @WeChat : meutils
|
8
8
|
# @Software : PyCharm
|
9
|
-
# @Description :
|
9
|
+
# @Description : pip install meutils openai-whisper pysrt opencc opencc-python-reimplemented -U
|
10
|
+
# export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/opt/miniconda/lib/python3.10/site-packages/nvidia/cudnn/lib
|
11
|
+
|
10
12
|
import pysrt
|
11
13
|
from datetime import timedelta
|
12
14
|
|
@@ -18,13 +20,12 @@ from faster_whisper.transcribe import Segment
|
|
18
20
|
|
19
21
|
from whisper.normalizers import BasicTextNormalizer, EnglishTextNormalizer
|
20
22
|
|
21
|
-
|
22
23
|
class ASR(object):
|
23
24
|
|
24
25
|
def __init__(self, model_size_or_path='base', local_files_only=True):
|
25
26
|
self.model = WhisperModel(
|
26
27
|
model_size_or_path=model_size_or_path,
|
27
|
-
local_files_only=local_files_only
|
28
|
+
local_files_only=local_files_only,
|
28
29
|
)
|
29
30
|
|
30
31
|
def audio_to_srt(self, audio, filename='subtitle.srt', **transcribe_kwargs):
|
@@ -35,9 +36,10 @@ class ASR(object):
|
|
35
36
|
self,
|
36
37
|
audio,
|
37
38
|
language: Optional[str] = 'zh',
|
39
|
+
task: str = "transcribe",
|
38
40
|
**kwargs # todo: 常用参数
|
39
41
|
):
|
40
|
-
segments, self.info = self.model.transcribe(str(audio), language=language)
|
42
|
+
segments, self.info = self.model.transcribe(str(audio), language=language, task=task, )
|
41
43
|
|
42
44
|
bn = BasicTextNormalizer()
|
43
45
|
|
@@ -93,11 +95,17 @@ class ASR(object):
|
|
93
95
|
|
94
96
|
|
95
97
|
if __name__ == '__main__':
|
96
|
-
|
98
|
+
model_size = "small"
|
99
|
+
# model_size = "large-v3"
|
100
|
+
# model_size = "Systran/faster-distil-whisper-large-v3"
|
101
|
+
asr = ASR(model_size_or_path=model_size, local_files_only=True)
|
97
102
|
# audio_path = '../../../../zh_.wav'
|
98
103
|
# audio_path = "/Users/betterme/Downloads/videoplayback.m4a"
|
99
104
|
# audio_path = "20190101-section_2.mp3"
|
100
105
|
# asr.audio_to_srt(audio_path)
|
101
106
|
|
102
|
-
for p in Path('
|
103
|
-
asr.audio_to_srt(
|
107
|
+
for p in Path('./').glob('*.mp3'):
|
108
|
+
asr.audio_to_srt(
|
109
|
+
p, f"./{p.parent.name}/{p.name.strip('.mp3')}.text",
|
110
|
+
)
|
111
|
+
break
|