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,373 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : suno
|
5
|
+
# @Time : 2024/3/27 20:37
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description :
|
10
|
+
|
11
|
+
|
12
|
+
import jsonpath
|
13
|
+
|
14
|
+
from meutils.pipe import *
|
15
|
+
from meutils.schemas.task_types import Task
|
16
|
+
from meutils.schemas.suno_types import SunoAIRequest
|
17
|
+
from meutils.schemas.suno_types import MODELS, BASE_URL, CLIENT_BASE_URL, UPLOAD_BASE_UR, STUDIO_BASE_URL
|
18
|
+
from meutils.schemas.suno_types import API_SESSION, API_FEED, API_BILLING_INFO, API_GENERATE_LYRICS, API_GENERATE_V2
|
19
|
+
|
20
|
+
from meutils.decorators.retry import retrying
|
21
|
+
from meutils.notice.feishu import send_message as _send_message
|
22
|
+
from meutils.config_utils.lark_utils import get_next_token_for_polling
|
23
|
+
from meutils.io.files_utils import to_bytes
|
24
|
+
|
25
|
+
FEISHU_URL = "https://xchatllm.feishu.cn/sheets/Bmjtst2f6hfMqFttbhLcdfRJnNf?sheet=Jxlglo"
|
26
|
+
FEISHU_URL_STEM = "https://xchatllm.feishu.cn/sheets/GYCHsvI4qhnDPNtI4VPcdw2knEd?sheet=rxldsA"
|
27
|
+
|
28
|
+
send_message = partial(
|
29
|
+
_send_message,
|
30
|
+
title=__name__,
|
31
|
+
url="https://open.feishu.cn/open-apis/bot/v2/hook/dc1eda96-348e-4cb5-9c7c-2d87d584ca18"
|
32
|
+
)
|
33
|
+
|
34
|
+
|
35
|
+
@alru_cache(ttl=3600)
|
36
|
+
# @retrying(max_retries=5, predicate=lambda r: not r)
|
37
|
+
async def get_refresh_token(token: str): # 定时更新一次就行
|
38
|
+
headers = {
|
39
|
+
"Cookie": f"__client={token}"
|
40
|
+
}
|
41
|
+
async with httpx.AsyncClient(base_url=CLIENT_BASE_URL, headers=headers, timeout=60) as client:
|
42
|
+
response = await client.get('')
|
43
|
+
|
44
|
+
# logger.debug(response.status_code)
|
45
|
+
# logger.debug(response.text)
|
46
|
+
|
47
|
+
if response.is_success:
|
48
|
+
data = response.json() # {"response":null,"client":null}
|
49
|
+
if not data.get("response"):
|
50
|
+
return token, None
|
51
|
+
|
52
|
+
if ids := jsonpath.jsonpath(data, "$..last_active_session_id"):
|
53
|
+
return token, ids[0] # last_active_session_id
|
54
|
+
|
55
|
+
send_message(f"未知错误:{response.status_code}\n\n{response.text}")
|
56
|
+
|
57
|
+
|
58
|
+
@alru_cache(ttl=30 - 3)
|
59
|
+
async def get_access_token(token: str):
|
60
|
+
_ = await get_refresh_token(token)
|
61
|
+
token, last_active_session_id = await get_refresh_token(token) # last_active_token 没啥用
|
62
|
+
|
63
|
+
headers = {
|
64
|
+
"Cookie": f"__client={token}",
|
65
|
+
}
|
66
|
+
|
67
|
+
params = {
|
68
|
+
"__clerk_api_version": "2021-02-05",
|
69
|
+
"_clerk_js_version": "5.35.1"
|
70
|
+
}
|
71
|
+
|
72
|
+
async with httpx.AsyncClient(base_url=CLIENT_BASE_URL, headers=headers, timeout=60) as client:
|
73
|
+
response = await client.post(f"/sessions/{last_active_session_id}/tokens", params=params)
|
74
|
+
response.raise_for_status()
|
75
|
+
logger.debug(bjson(response.json()))
|
76
|
+
return response.json().get('jwt')
|
77
|
+
|
78
|
+
# /tokens?__clerk_api_version=2021-02-05&_clerk_js_version=5.35.1
|
79
|
+
|
80
|
+
@retrying(predicate=lambda r: not r)
|
81
|
+
async def create_task(request: SunoAIRequest, token: Optional[str] = None):
|
82
|
+
token = token or await get_next_token_for_polling(FEISHU_URL, check_token=check_token, from_redis=True)
|
83
|
+
|
84
|
+
access_token = await get_access_token(token)
|
85
|
+
|
86
|
+
headers = {
|
87
|
+
"Authorization": f"Bearer {access_token}",
|
88
|
+
}
|
89
|
+
payload = request.model_dump(exclude_none=True)
|
90
|
+
async with httpx.AsyncClient(base_url=BASE_URL, headers=headers, timeout=60) as client:
|
91
|
+
response = await client.post(API_GENERATE_V2, json=payload)
|
92
|
+
if response.is_success:
|
93
|
+
data = response.json()
|
94
|
+
task_id, *clip_ids = jsonpath.jsonpath(data, "$..id")
|
95
|
+
clip_ids = [i for i in clip_ids if not str(i).startswith("m_")]
|
96
|
+
|
97
|
+
task_id = f"suno-{','.join(clip_ids)}" # 需要返回的任务id
|
98
|
+
return Task(id=task_id, data=data, system_fingerprint=token)
|
99
|
+
|
100
|
+
response.raise_for_status()
|
101
|
+
|
102
|
+
|
103
|
+
@alru_cache(ttl=15)
|
104
|
+
@retrying(predicate=lambda r: not r) # 触发重试
|
105
|
+
async def get_task(task_id, token: str): # task_id 实际是 clip_ids, 必须指定token获取任务
|
106
|
+
task_id = task_id.split("suno-")[-1]
|
107
|
+
|
108
|
+
access_token = await get_access_token(token)
|
109
|
+
headers = {
|
110
|
+
"Authorization": f"Bearer {access_token}",
|
111
|
+
}
|
112
|
+
|
113
|
+
params = {"ids": task_id}
|
114
|
+
async with httpx.AsyncClient(base_url=BASE_URL, headers=headers, timeout=60) as client:
|
115
|
+
response = await client.get(API_FEED, params=params)
|
116
|
+
if response.is_success:
|
117
|
+
return response.json()
|
118
|
+
|
119
|
+
|
120
|
+
@alru_cache(ttl=15)
|
121
|
+
@retrying(predicate=lambda r: not r) # 触发重试
|
122
|
+
async def generate_lyrics(prompt: str = '', token: Optional[str] = None):
|
123
|
+
token = token or await get_next_token_for_polling(FEISHU_URL)
|
124
|
+
|
125
|
+
access_token = await get_access_token(token)
|
126
|
+
headers = {
|
127
|
+
"Authorization": f"Bearer {access_token}",
|
128
|
+
}
|
129
|
+
|
130
|
+
payload = {"prompt": prompt}
|
131
|
+
|
132
|
+
async with httpx.AsyncClient(base_url=BASE_URL, headers=headers, timeout=60) as client:
|
133
|
+
response = await client.post(API_GENERATE_LYRICS, json=payload)
|
134
|
+
if response.is_success:
|
135
|
+
task_id = response.json().get("id")
|
136
|
+
|
137
|
+
for i in range(100):
|
138
|
+
response = await client.get(API_GENERATE_LYRICS + task_id)
|
139
|
+
|
140
|
+
logger.debug(response.text)
|
141
|
+
|
142
|
+
if response.is_success:
|
143
|
+
if response.json().get("status") == "complete": # "status": "complete"
|
144
|
+
return response.json() # todo: 大模型写歌词兜底
|
145
|
+
elif response.json().get("status") == "error": # 退出
|
146
|
+
# send_message(f"生成歌词失败:{response.text}")
|
147
|
+
return "可能触发内容审核,请检查提示词"
|
148
|
+
|
149
|
+
if i > 30:
|
150
|
+
response.raise_for_status()
|
151
|
+
|
152
|
+
await asyncio.sleep(1 if i < 3 else 0.5)
|
153
|
+
response.raise_for_status()
|
154
|
+
|
155
|
+
|
156
|
+
@alru_cache(ttl=3600)
|
157
|
+
async def upload(file: bytes, title: str = 'xx.wav', token: Optional[str] = None): # 必须指定token获取任务
|
158
|
+
token = token or await get_next_token_for_polling(FEISHU_URL)
|
159
|
+
|
160
|
+
access_token = await get_access_token(token)
|
161
|
+
headers = {
|
162
|
+
"Authorization": f"Bearer {access_token}",
|
163
|
+
}
|
164
|
+
|
165
|
+
async with httpx.AsyncClient(timeout=100) as client:
|
166
|
+
# payload = {"extension": "wav"} # "{\"extension\":\"wav\"}"
|
167
|
+
payload = "{\"extension\":\"wav\"}"
|
168
|
+
payload = "{\"extension\":\"\"}"
|
169
|
+
response = await client.post(f"{BASE_URL}/api/uploads/audio/", content=payload, headers=headers)
|
170
|
+
|
171
|
+
# logger.debug(response.text)
|
172
|
+
|
173
|
+
if response.is_success:
|
174
|
+
data = response.json()
|
175
|
+
logger.debug(data)
|
176
|
+
|
177
|
+
file_id = data.get("id")
|
178
|
+
# file_id = Path(data.get("fields").get('key')).stem
|
179
|
+
|
180
|
+
payload = data.get("fields")
|
181
|
+
files = {
|
182
|
+
'file': file
|
183
|
+
# 'file': ("xx", file, 'audio/mpeg')
|
184
|
+
# 'file': (title, file, 'audio/wav')
|
185
|
+
}
|
186
|
+
|
187
|
+
response = await client.post(url=UPLOAD_BASE_UR, data=payload, files=files)
|
188
|
+
logger.debug(response.status_code)
|
189
|
+
if response.is_success:
|
190
|
+
payload = {"upload_type": "file_upload", "upload_filename": title}
|
191
|
+
response = await client.post(
|
192
|
+
f"{BASE_URL}/api/uploads/audio/{file_id}/upload-finish/",
|
193
|
+
headers=headers,
|
194
|
+
json=payload
|
195
|
+
)
|
196
|
+
for i in range(30):
|
197
|
+
response = await client.get(f"{BASE_URL}/api/uploads/audio/{file_id}/", headers=headers)
|
198
|
+
if response.is_success and response.json().get("s3_id"):
|
199
|
+
logger.debug(response.json())
|
200
|
+
break
|
201
|
+
|
202
|
+
# {
|
203
|
+
# "id": "557f349e-2ce5-45f0-806c-efba18286599",
|
204
|
+
# "status": "complete",
|
205
|
+
# "error_message": null,
|
206
|
+
# "s3_id": "m_476a2e21-a0aa-4e33-92ff-2b5ddd587661",
|
207
|
+
# "title": "audio",
|
208
|
+
# "image_url": "https://cdn1.suno.ai/image_476a2e21-a0aa-4e33-92ff-2b5ddd587661.png"
|
209
|
+
# }
|
210
|
+
# {"id": "5d39c704-52c2-4d32-9bef-ac06c2c84dab", "status": "error",
|
211
|
+
# "error_message": "Uploaded audio is too short (currently 1.5 seconds). Minimum duration is 6 seconds.",
|
212
|
+
# "s3_id": null, "title": "", "image_url": null}
|
213
|
+
|
214
|
+
elif response.json().get("status") == "error":
|
215
|
+
logger.error(response.text)
|
216
|
+
raise Exception(response.text)
|
217
|
+
if i == 1:
|
218
|
+
logger.debug(response.status_code)
|
219
|
+
logger.debug(response.text)
|
220
|
+
await asyncio.sleep(3)
|
221
|
+
else:
|
222
|
+
await asyncio.sleep(0.5)
|
223
|
+
|
224
|
+
response = await client.post(
|
225
|
+
f"{BASE_URL}/api/uploads/audio/{file_id}/initialize-clip/",
|
226
|
+
headers=headers
|
227
|
+
)
|
228
|
+
clip_id = response.json().get("clip_id") # m_{clip_id} image_{clip_id}.png
|
229
|
+
|
230
|
+
payload = {"id": clip_id, "title": title} # 好像不要也行,前端展示 title 传入文件名
|
231
|
+
resp = await client.post(f"{BASE_URL}/api/gen/{clip_id}/set_metadata/", json=payload, headers=headers)
|
232
|
+
|
233
|
+
data = await get_task(task_id=clip_id, token=token) # 绑定token才能获取
|
234
|
+
return data, token # clip_id: token 存一下
|
235
|
+
|
236
|
+
else:
|
237
|
+
response.raise_for_status()
|
238
|
+
|
239
|
+
|
240
|
+
async def get_credits(token):
|
241
|
+
access_token = await get_access_token(token)
|
242
|
+
headers = {
|
243
|
+
"Authorization": f"Bearer {access_token}",
|
244
|
+
}
|
245
|
+
async with httpx.AsyncClient(base_url=BASE_URL, timeout=100, headers=headers) as client:
|
246
|
+
response = await client.get(API_BILLING_INFO)
|
247
|
+
response.raise_for_status()
|
248
|
+
if response.is_success:
|
249
|
+
data = response.json()
|
250
|
+
# logger.debug(bjson(data))
|
251
|
+
return data
|
252
|
+
|
253
|
+
|
254
|
+
async def check_token(token, threshold=10):
|
255
|
+
try:
|
256
|
+
data = await get_credits(token)
|
257
|
+
|
258
|
+
logger.debug(data['total_credits_left'])
|
259
|
+
|
260
|
+
return data['total_credits_left'] >= threshold # 视频
|
261
|
+
except Exception as e:
|
262
|
+
logger.error(f"{e}\n无效\n{token}")
|
263
|
+
return False
|
264
|
+
|
265
|
+
|
266
|
+
@retrying()
|
267
|
+
async def create_task_for_stems(stem_from_url):
|
268
|
+
token = await get_next_token_for_polling(FEISHU_URL_STEM)
|
269
|
+
access_token = await get_access_token(token)
|
270
|
+
|
271
|
+
file = await to_bytes(stem_from_url)
|
272
|
+
data, _ = await upload(file, token=token)
|
273
|
+
logger.debug(bjson(data))
|
274
|
+
stem_from_id = data[0]['id'] #
|
275
|
+
|
276
|
+
headers = {
|
277
|
+
"Authorization": f"Bearer {access_token}",
|
278
|
+
}
|
279
|
+
async with httpx.AsyncClient(base_url=BASE_URL, headers=headers, timeout=60) as client:
|
280
|
+
response = await client.post(f"/api/edit/stems/{stem_from_id}/")
|
281
|
+
response.raise_for_status()
|
282
|
+
if response.is_success:
|
283
|
+
data = response.json()
|
284
|
+
clip_ids = jsonpath.jsonpath(data, "$..id")
|
285
|
+
|
286
|
+
task_id = f"suno-{','.join(clip_ids)}" # 需要返回的任务id
|
287
|
+
return Task(id=task_id, data=data, system_fingerprint=token)
|
288
|
+
|
289
|
+
|
290
|
+
@retrying()
|
291
|
+
async def create_task_for_cover(cover_from_url, lyrics):
|
292
|
+
token = await get_next_token_for_polling(FEISHU_URL_STEM)
|
293
|
+
access_token = await get_access_token(token)
|
294
|
+
|
295
|
+
file = await to_bytes(cover_from_url)
|
296
|
+
data, _ = await upload(file, token=token)
|
297
|
+
cover_from_id = data[0]['id']
|
298
|
+
|
299
|
+
headers = {
|
300
|
+
"Authorization": f"Bearer {access_token}",
|
301
|
+
}
|
302
|
+
payload = SunoAIRequest(
|
303
|
+
task="cover",
|
304
|
+
mv="chirp-v3-5-tau",
|
305
|
+
cover_clip_id=cover_from_id,
|
306
|
+
prompt=lyrics,
|
307
|
+
).model_dump(exclude_none=True)
|
308
|
+
|
309
|
+
async with httpx.AsyncClient(base_url=BASE_URL, headers=headers, timeout=60) as client:
|
310
|
+
response = await client.post(API_GENERATE_V2, json=payload)
|
311
|
+
if response.is_success:
|
312
|
+
data = response.json()
|
313
|
+
task_id, *clip_ids = jsonpath.jsonpath(data, "$..id")
|
314
|
+
clip_ids = [i for i in clip_ids if not str(i).startswith("m_")]
|
315
|
+
|
316
|
+
task_id = f"suno-{','.join(clip_ids)}" # 需要返回的任务id
|
317
|
+
return Task(id=task_id, data=data, system_fingerprint=token)
|
318
|
+
|
319
|
+
response.raise_for_status()
|
320
|
+
|
321
|
+
|
322
|
+
if __name__ == '__main__':
|
323
|
+
# token = os.getenv("SUNO_API_KEY")
|
324
|
+
# token = "eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6ImNsaWVudF8yaGlHSTlCZFVwOUdZcUlGM3ZmTU1IT25SNFAiLCJyb3RhdGluZ190b2tlbiI6ImltOWMzOGJ4bnV2OThiZXplMW8yOG1zd2Y2c3lrdzd6YnM2ejJubHkifQ.SnC8-G2LVQztTiA2davFS413mQIaBmRFDzIw1JmvHg4UOMXq95z0CgbfK8Gx8Zv-FXdpKVqkamiNTzZP9qsLOSgREqCSSq5bmA6SPIWx-R6dj1PMDFRX-qv5qGyyPe4sadF6wnr45MS9859148gRmr_Go8rAT_7Hu0DKySextl-Xbs6ClDaYYUyyV3HudWQh4F8jwvxkyer05AgN6smQH5eZI-NRKVgZn_i6Mtl8IJz8R1fzD2YNIcvH4QC4qGhrg9n74ljIeORCMsoJzW2SBZa4QWWDx_0VYs-tA_Z43bqwN_2ojMGM63fm2hLOZmwf6S1LQy9_O6UdcUQiEs__OA"
|
325
|
+
token = "eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6ImNsaWVudF8ybEIwRFlXTWYya3NxNWlxazl4S2dZbmQ0eVciLCJyb3RhdGluZ190b2tlbiI6Im5vejdpMzlvY2YzMTEzaHp6aDZwY2N5MzltZm5xNmZvdnhtOG9oNngifQ.qUeBLl-NxKzhpoUBpo_EwkHH0qwIsG0nMSD_yvHv5EK7YfybupoPWw8SpSKDhmZu5K_KsgdOF0RQH22jll4U-x0BwfVu1ze-GBxjnNEoSerUB7hu1cfvmg7xMH8rHJQig2TWE2h0hzP6dMajPHQWRTltbb5MMkKHgBFj0CiAFqaGwzSSvAtERwwHBIK3KalbaV1oyd6DJYG4FrVgQLubkp7VXj11LszxD6qXklRhsc9h55kvYASDPHhnZJi9u2QfIbiKVkraXb6ShqDmNtqXbj22p6g2R9fwMEB-m68S7QSZyAWRArWzsSZujzhxmNuMGbuVX1v7op7F3hA2zFphYw"
|
326
|
+
# print(arun(get_refresh_token(token)))
|
327
|
+
print(arun(get_access_token(token)))
|
328
|
+
|
329
|
+
# arun(generate_lyrics(prompt=''))
|
330
|
+
|
331
|
+
# ids = "ee6d4369-3c75-4526-b6f1-b5f2f271cf30"
|
332
|
+
# print(api_feed(api_key, ids))
|
333
|
+
|
334
|
+
# for i in range(100): # 测试过期时间
|
335
|
+
# print(api_billing_info(api_key))
|
336
|
+
# time.sleep(60)
|
337
|
+
|
338
|
+
# print(arun(get_api_key()))
|
339
|
+
# task_id = music_ids = 1
|
340
|
+
# send_message(f"""
|
341
|
+
# https://api.chatfire.cn/task/suno/v1/tasks/{task_id}
|
342
|
+
# https://api.chatfire.cn/task/suno/v1/music/{music_ids}
|
343
|
+
# """)
|
344
|
+
# file = open("/Users/betterme/PycharmProjects/AI/test.mp3", 'rb').read()
|
345
|
+
# file = open("/Users/betterme/Downloads/audio.wav", 'rb').read()
|
346
|
+
# arun(upload(file=file))
|
347
|
+
# token = "eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6ImNsaWVudF8yajM1dkNXaTE1b0VQWnlUU0RMMnBsU3RiMVQiLCJyb3RhdGluZ190b2tlbiI6Ijd5MDV0cG1nMWJpbjBmaGIxZW1kYzZoazQzbDRuaG84bmJ4Yzc1dzgifQ.LsEfuPgwXu33f_UD2pRY4HjHIwU_rPG2rvG46BVDKqXcPmhRTWl5LjKgFrSzU51tgxfG-wMopVJhRxgS6YZUMtKVojDFtV_ZImyJ30u6LYA5nSbrkhqUrBdU4P5WmkL9irvh4sGPtvv8ML_pyXzsittsDrNnDCtm_isacOD-Fy3VKOCOjWj4W3qUUdnmBvTeeUbrnepQqurAjYPg6Ug-WkR43xZ5tWtxxTQ4ebtZglgRyCbyF3TM9XMKa67FTwHQsja8cLo2CyGRzb89e3uuF8Na_CY17ZlxJyQ2p_FZmL0egWr0EveZFeVzIUUs704pkhKd-RC9Q47Jqcg8qdiRYA"
|
348
|
+
# arun(generate_lyrics('hi', token))
|
349
|
+
# arun(generate_lyrics())
|
350
|
+
# task_id = "0b017d4e-c559-4cc6-9339-9cd53aa25af4"
|
351
|
+
# token = "eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6ImNsaWVudF8ybEIwRFlXTWYya3NxNWlxazl4S2dZbmQ0eVciLCJyb3RhdGluZ190b2tlbiI6Im5vejdpMzlvY2YzMTEzaHp6aDZwY2N5MzltZm5xNmZvdnhtOG9oNngifQ.qUeBLl-NxKzhpoUBpo_EwkHH0qwIsG0nMSD_yvHv5EK7YfybupoPWw8SpSKDhmZu5K_KsgdOF0RQH22jll4U-x0BwfVu1ze-GBxjnNEoSerUB7hu1cfvmg7xMH8rHJQig2TWE2h0hzP6dMajPHQWRTltbb5MMkKHgBFj0CiAFqaGwzSSvAtERwwHBIK3KalbaV1oyd6DJYG4FrVgQLubkp7VXj11LszxD6qXklRhsc9h55kvYASDPHhnZJi9u2QfIbiKVkraXb6ShqDmNtqXbj22p6g2R9fwMEB-m68S7QSZyAWRArWzsSZujzhxmNuMGbuVX1v7op7F3hA2zFphYw"
|
352
|
+
# arun(get_task(task_id=task_id, token=token))
|
353
|
+
|
354
|
+
# arun(get_credits(token))
|
355
|
+
# arun(check_token(token))
|
356
|
+
|
357
|
+
# arun(upload(Path('cover.mp3').read_bytes(), title="翻唱"))
|
358
|
+
url = "https://cdn1.suno.ai/14d5afd8-057e-4d97-bc13-b8521dde568a.mp3"
|
359
|
+
|
360
|
+
# arun(create_task_for_stems(url))
|
361
|
+
#
|
362
|
+
# arun(get_task("suno-644b4e39-abd5-44c0-95cb-25ee56b0f6ed,ee0443b2-af84-4fb5-b29d-d23d41ce8142", token=token))
|
363
|
+
# lyrics = """
|
364
|
+
# [Verse]\n每天天还未亮\n我们已经在路上\n辛苦工作拼命干\n工资却总是拖欠\n\n[Verse 2]\n加班加点不休息\n老板总是不提起\n口袋越来越空虚\n哪里是我们的权益\n\n[Chorus]\n一起团结呼吁\n要把话语权夺回\n为我们的权利\n我们绝不喊后退\n\n[Bridge]\n不怕辛劳与压力\n只怕公正被歪曲\n强忍泪水背负艰辛\n梦想不可被抹去\n\n[Verse 3]\n工资迟迟不见影\n梦想渐渐被耗尽\n但我们心不认命\n勇敢站出来喊停\n\n[Chorus]\n一起团结呼吁\n要把话语权夺回\n为我们的权利\n我们绝不喊后退
|
365
|
+
# """
|
366
|
+
# arun(create_task_for_cover(url, lyrics))
|
367
|
+
|
368
|
+
# token = "eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6ImNsaWVudF8yazY3OG5pWWI5M2xjWHQ2a1dZMVNSalcxNVQiLCJyb3RhdGluZ190b2tlbiI6Imk2bzE0eXkxMW5mNTduaXFpcG9kOWx2cHBrbXBvbG16bTdqMDQ3bXQifQ.mD5dwo6c1xyg4kS_Z6Nwz4N_UonetHBFLcvHRTGTsqd4Pc-QYTEJ2IiedILX7nrA1b3K-mhN-M9isyzUxl3Pa9DCqQ4p9snsib_Rz-v_ou2V-rOORPHLwzIQSZbkE4gDyH4DF_UT6TqZRp_KkOyPEmyGQHQWjiUDuWv7CjDXM0AbqhV0gafCKA6cQ0ZdL9yKNq_0rFgIWP9mRrDGP6r237gXqLm84SmlhtMpob5T_QByCpunmTKe2Gi9qNEkKm_8EHAKSw3vj9XHBH3cMsiVPO47cT_rs98tIUq20sqk4C6hlL7mhLomm9L33k4wVTgyH7ln8UK9xxQ3lGm-W-mjKA"
|
369
|
+
#
|
370
|
+
# arun(get_credits(token))
|
371
|
+
|
372
|
+
# arun(generate_lyrics('hi'))
|
373
|
+
# arun(create_task(SunoAIRequest(prompt='写首中国风的歌曲')))
|
@@ -0,0 +1,25 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : demo
|
5
|
+
# @Time : 2024/9/18 10:39
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description :
|
10
|
+
import re
|
11
|
+
|
12
|
+
from meutils.pipe import *
|
13
|
+
|
14
|
+
HTML_PARSER = re.compile(r'```html(.*?)```', re.DOTALL)
|
15
|
+
s = """
|
16
|
+
这是一堆文本
|
17
|
+
```html
|
18
|
+
这是一段html
|
19
|
+
```
|
20
|
+
这是一堆文本
|
21
|
+
"""
|
22
|
+
|
23
|
+
print(HTML_PARSER.findall(s))
|
24
|
+
|
25
|
+
# {"messages":[{"role":"user","content":"早饭"}],"chat_id":"ssZZTRs","model":"Qwen/Qwen2-Math-72B-Instruct"}
|
@@ -0,0 +1,81 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : hanyuxinjie
|
5
|
+
# @Time : 2024/9/18 13:30
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description :
|
10
|
+
|
11
|
+
from meutils.pipe import *
|
12
|
+
|
13
|
+
BASE_URL = 'https://xy.siliconflow.cn'
|
14
|
+
|
15
|
+
HTML_PARSER = re.compile(r'```html(.*?)```', re.DOTALL)
|
16
|
+
|
17
|
+
|
18
|
+
# s = """
|
19
|
+
# 这是一堆文本
|
20
|
+
# ```html
|
21
|
+
# 这是一段html
|
22
|
+
# ```
|
23
|
+
# 这是一堆文本
|
24
|
+
# """
|
25
|
+
#
|
26
|
+
# print(HTML_PARSER.findall(s))
|
27
|
+
|
28
|
+
|
29
|
+
async def create(
|
30
|
+
prompt: str = '996',
|
31
|
+
model: str = "meta-llama/Meta-Llama-3.1-405B-Instruct",
|
32
|
+
title: str = "🔥汉语新解",
|
33
|
+
):
|
34
|
+
"""
|
35
|
+
"Pro/THUDM/glm-4-9b-chat"
|
36
|
+
"Qwen/Qwen2-Math-72B-Instruct"
|
37
|
+
“deepseek-ai/DeepSeek-V2.5”
|
38
|
+
"meta-llama/Meta-Llama-3.1-405B-Instruct"
|
39
|
+
"""
|
40
|
+
payload = {
|
41
|
+
"messages": [
|
42
|
+
{
|
43
|
+
"role": "user",
|
44
|
+
"content": prompt
|
45
|
+
}
|
46
|
+
],
|
47
|
+
# "chat_id": "i8yw46k",
|
48
|
+
"model": model
|
49
|
+
}
|
50
|
+
async with httpx.AsyncClient(base_url=BASE_URL, timeout=300) as client:
|
51
|
+
async with client.stream(method="POST", url="/api/chat", json=payload) as response:
|
52
|
+
# logger.debug(response.status_code)
|
53
|
+
async for chunk in response.aiter_lines():
|
54
|
+
# for chunk in "response.aiter_lines()":
|
55
|
+
yield chunk.replace("智说新语", title)
|
56
|
+
|
57
|
+
|
58
|
+
if __name__ == '__main__':
|
59
|
+
pass
|
60
|
+
# model = "Pro/THUDM/glm-4-9b-chat"
|
61
|
+
model = "Qwen/Qwen2.5-72B-Instruct"
|
62
|
+
model = "deepseek-ai/DeepSeek-V2.5"
|
63
|
+
|
64
|
+
# arun(create(text="火宝", model="meta-llama/Meta-Llama-3.1-405B-Instruct"))
|
65
|
+
|
66
|
+
# arun(create(text="火宝", model="google/gemma-2-27b-it"))
|
67
|
+
|
68
|
+
# arun(create(prompt="火宝", model=model))
|
69
|
+
|
70
|
+
# arun(main(create(text="火宝", model="Qwen/Qwen2-Math-72B-Instruct", stream=True)))
|
71
|
+
s = """
|
72
|
+
这是一堆文本
|
73
|
+
``html
|
74
|
+
这是一段html
|
75
|
+
```
|
76
|
+
这是一堆文本
|
77
|
+
"""
|
78
|
+
|
79
|
+
print(HTML_PARSER.findall(s))
|
80
|
+
|
81
|
+
arun(create(prompt="996", model=model))
|
meutils/apis/textin.py
ADDED
@@ -0,0 +1,159 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
# @Project : AI. @by PyCharm
|
4
|
+
# @File : textin
|
5
|
+
# @Time : 2024/6/26 08:22
|
6
|
+
# @Author : betterme
|
7
|
+
# @WeChat : meutils
|
8
|
+
# @Software : PyCharm
|
9
|
+
# @Description : todo: 重构 https://tools.textin.com/
|
10
|
+
# https://www.textin.com/console/recognition/robot_enhance?service=watermark-remove
|
11
|
+
|
12
|
+
# proxies 取消了 https://github.com/encode/httpx/pull/2879
|
13
|
+
|
14
|
+
from meutils.pipe import *
|
15
|
+
from meutils.decorators.retry import retrying
|
16
|
+
from meutils.notice.feishu import send_message
|
17
|
+
from meutils.io.files_utils import to_url
|
18
|
+
from meutils.apis.proxy.ips import get_one_proxy
|
19
|
+
|
20
|
+
from fake_useragent import UserAgent
|
21
|
+
|
22
|
+
ua = UserAgent()
|
23
|
+
|
24
|
+
BASE_URL = "https://api.textin.com/home"
|
25
|
+
|
26
|
+
proxy = "http://110.42.51.201:38443"
|
27
|
+
|
28
|
+
|
29
|
+
@alru_cache(ttl=3600 * 24)
|
30
|
+
async def document_process(data: bytes,
|
31
|
+
service: str = "pdf_to_markdown",
|
32
|
+
response_format: str = "url",
|
33
|
+
token: Optional[str] = None, # 821480df15b637852f7e4a0dabb8a156
|
34
|
+
**kwargs):
|
35
|
+
"""
|
36
|
+
|
37
|
+
:param data:
|
38
|
+
:param service: pdf_to_markdown watermark-remove dewarp
|
39
|
+
:param response_format:
|
40
|
+
:param kwargs:
|
41
|
+
:return:
|
42
|
+
"""
|
43
|
+
|
44
|
+
params = {
|
45
|
+
"service": service,
|
46
|
+
**kwargs
|
47
|
+
|
48
|
+
# "page_count": page_count,
|
49
|
+
# "get_image": "objects"
|
50
|
+
# "apply_document_tree": 0,
|
51
|
+
}
|
52
|
+
|
53
|
+
request_kwargs = {}
|
54
|
+
# request_kwargs = {"proxies": proxies}
|
55
|
+
|
56
|
+
for i in range(3):
|
57
|
+
|
58
|
+
headers = {
|
59
|
+
"token": token or str(uuid.uuid4()).replace("-", ""),
|
60
|
+
'User-Agent': ua.random,
|
61
|
+
}
|
62
|
+
try:
|
63
|
+
async with httpx.AsyncClient(base_url=BASE_URL, timeout=60, headers=headers, **request_kwargs) as client:
|
64
|
+
response = await client.post('/user_trial_ocr', content=data, params=params)
|
65
|
+
response.raise_for_status()
|
66
|
+
|
67
|
+
logger.debug(response.status_code)
|
68
|
+
# logger.info(response.json()) # {'msg': '今日请求超过限制次数', 'code': 431}
|
69
|
+
|
70
|
+
_ = response.json()
|
71
|
+
|
72
|
+
if '今日请求超过限制次数' in str(_):
|
73
|
+
# logger.info(response.json())
|
74
|
+
raise Exception("更新请求头或者加代理")
|
75
|
+
else:
|
76
|
+
break
|
77
|
+
|
78
|
+
|
79
|
+
except Exception as e: # 加代理
|
80
|
+
logger.error(e)
|
81
|
+
|
82
|
+
request_kwargs = {
|
83
|
+
"proxy": await get_one_proxy(),
|
84
|
+
# "proxy": proxy,
|
85
|
+
|
86
|
+
}
|
87
|
+
|
88
|
+
if response_format == "url" and service in {"watermark-remove", "crop_enhance_image"}:
|
89
|
+
if "data" not in _:
|
90
|
+
send_message(_, title=__name__)
|
91
|
+
|
92
|
+
# _ => {'msg': '今日请求超过限制次数', 'code': 431}
|
93
|
+
logger.debug(bjson(_))
|
94
|
+
# logger.debug(list(_['data']['result']['image']))
|
95
|
+
|
96
|
+
url = await to_url(_['data']['result']['image'])
|
97
|
+
_ = {"data": [{"url": url}]}
|
98
|
+
|
99
|
+
# _['data']['result']['image'] = await to_url(_['data']['result']['image'])
|
100
|
+
|
101
|
+
return _
|
102
|
+
|
103
|
+
|
104
|
+
if __name__ == '__main__':
|
105
|
+
from meutils.io.files_utils import to_bytes, to_url
|
106
|
+
|
107
|
+
# data = open("/Users/betterme/PycharmProjects/AI/11.jpg", 'rb').read()
|
108
|
+
# # data = open("/Users/betterme/PycharmProjects/AI/蚂蚁集团招股书.pdf", 'rb').read()
|
109
|
+
# with timer("解析"):
|
110
|
+
# # arun(textin_fileparser(data))
|
111
|
+
# print(arun(textin_fileparser(data, service="pdf_to_markdown")))
|
112
|
+
|
113
|
+
# response = requests.request("POST", url, data=data)
|
114
|
+
data = open("/Users/betterme/PycharmProjects/AI/qun.png", 'rb').read()
|
115
|
+
data = open("img.png", 'rb').read()
|
116
|
+
# data = arun(to_bytes("https://cdn.meimeiqushuiyin.cn/ori/tmp_e8d6329e1b2c1bc541ca530fcbae14e3ec12f65d8d4ec97d.jpg"))
|
117
|
+
|
118
|
+
from meutils.schemas.task_types import Purpose
|
119
|
+
|
120
|
+
service = Purpose.watermark_remove.value
|
121
|
+
|
122
|
+
# service = "pdf_to_markdown"
|
123
|
+
|
124
|
+
service = 'bill_recognize_v2'
|
125
|
+
|
126
|
+
|
127
|
+
async def main(n=1):
|
128
|
+
for i in tqdm(range(n)):
|
129
|
+
try:
|
130
|
+
_ = await document_process(data, service=service)
|
131
|
+
logger.debug(bjson(_))
|
132
|
+
except Exception as e:
|
133
|
+
logger.error(f"{i}: {e}")
|
134
|
+
break
|
135
|
+
|
136
|
+
|
137
|
+
# with timer("解析"):
|
138
|
+
#
|
139
|
+
# # arun(textin_fileparser(data))
|
140
|
+
# data = arun(document_process(data, service=service))
|
141
|
+
#
|
142
|
+
# # b64 = data['data']['result']['image']
|
143
|
+
#
|
144
|
+
# # base64_to_file(b64, "demo.png")
|
145
|
+
#
|
146
|
+
# # data['data']['result']['image'] = arun(to_url(b64))
|
147
|
+
#
|
148
|
+
# logger.debug(data)
|
149
|
+
#
|
150
|
+
# # {'msg': 'success',
|
151
|
+
# # 'data': {
|
152
|
+
# # 'result': {
|
153
|
+
# # 'image': 'https://sfile.chatglm.cn/chatglm-videoserver/image/e5/e5d4011c.png'
|
154
|
+
# # },
|
155
|
+
# # 'file_type': '', 'file_data': ''
|
156
|
+
# # }, 'code': 200
|
157
|
+
# # }
|
158
|
+
|
159
|
+
arun(main(1))
|