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.
Files changed (582) hide show
  1. {MeUtils-2024.3.4.13.4.45.dist-info → MeUtils-2025.1.16.17.15.52.dist-info}/METADATA +38 -32
  2. MeUtils-2025.1.16.17.15.52.dist-info/RECORD +864 -0
  3. {MeUtils-2024.3.4.13.4.45.dist-info → MeUtils-2025.1.16.17.15.52.dist-info}/WHEEL +1 -1
  4. {MeUtils-2024.3.4.13.4.45.dist-info → MeUtils-2025.1.16.17.15.52.dist-info}/entry_points.txt +1 -0
  5. apps/spider.py +24 -8
  6. examples/_openaisdk/4v.py +110 -0
  7. examples/_openaisdk/__init__.py +11 -0
  8. examples/_openaisdk/baichuan.py +38 -0
  9. examples/_openaisdk/bpo.py +138 -0
  10. examples/_openaisdk/chat_latex.py +95 -0
  11. examples/_openaisdk/chattts.py +85 -0
  12. examples/_openaisdk/copilot.py +48 -0
  13. examples/_openaisdk/dalle3.py +48 -0
  14. examples/_openaisdk/deeplx.py +31 -0
  15. examples/_openaisdk/demo.py +77 -0
  16. examples/_openaisdk/embeddings.py +34 -0
  17. examples/_openaisdk/gpt4all.py +69 -0
  18. examples/_openaisdk/gpt_fc.py +23 -0
  19. examples/_openaisdk/gr_vl.py +46 -0
  20. examples/_openaisdk/json_mode.py +12 -0
  21. examples/_openaisdk/kimi.py +91 -0
  22. examples/_openaisdk/kimi_qa.py +57 -0
  23. examples/_openaisdk/minimax.py +75 -0
  24. examples/_openaisdk/open_router.py +48 -0
  25. examples/_openaisdk/openai_aiplus.py +54 -0
  26. examples/_openaisdk/openai_audio.py +20 -0
  27. examples/_openaisdk/openai_baichuan.py +59 -0
  28. examples/_openaisdk/openai_cache.py +37 -0
  29. examples/_openaisdk/openai_chatfire.py +228 -0
  30. examples/_openaisdk/openai_chatfire_all.py +166 -0
  31. examples/_openaisdk/openai_deepinfra.py +55 -0
  32. examples/_openaisdk/openai_deepseek.py +29 -0
  33. examples/_openaisdk/openai_doubao.py +43 -0
  34. examples/_openaisdk/openai_embeddings.py +36 -0
  35. examples/_openaisdk/openai_files.py +57 -0
  36. examples/_openaisdk/openai_gitee.py +33 -0
  37. examples/_openaisdk/openai_god.py +45 -0
  38. examples/_openaisdk/openai_groq.py +240 -0
  39. examples/_openaisdk/openai_images.py +203 -0
  40. examples/_openaisdk/openai_json.py +78 -0
  41. examples/_openaisdk/openai_lingyi.py +59 -0
  42. examples/_openaisdk/openai_modelscope.py +54 -0
  43. examples/_openaisdk/openai_moon.py +55 -0
  44. examples/_openaisdk/openai_oi.py +61 -0
  45. examples/_openaisdk/openai_ppu.py +47 -0
  46. examples/_openaisdk/openai_qwen.py +58 -0
  47. examples/_openaisdk/openai_search.py +42 -0
  48. examples/_openaisdk/openai_sensenova.py +81 -0
  49. examples/_openaisdk/openai_siliconflow.py +52 -0
  50. examples/_openaisdk/openai_step.py +45 -0
  51. examples/_openaisdk/openai_test.py +66 -0
  52. examples/_openaisdk/openai_together.py +57 -0
  53. examples/_openaisdk/openai_tune.py +38 -0
  54. examples/_openaisdk/openai_zhipu.py +59 -0
  55. examples/_openaisdk/ppu.py +28 -0
  56. examples/_openaisdk/rag.py +54 -0
  57. examples/_openaisdk/rag_.py +26 -0
  58. examples/_openaisdk/test.py +52 -0
  59. examples/_openaisdk/x.py +32 -0
  60. examples/_openaisdk/xx.py +29 -0
  61. examples/_openaisdk/zhipu_files.py +47 -0
  62. examples/_openaisdk/zhipu_/346/231/272/350/203/275/344/275/223.py +45 -0
  63. examples/_openaisdk//345/205/234/345/272/225/346/265/213/350/257/225.py +50 -0
  64. examples/_openaisdk//345/244/232/346/250/241/346/200/201/346/265/213/350/257/225.py +76 -0
  65. examples/_openaisdk//345/244/232/346/250/241/346/200/201/346/265/213/350/257/225_.py +56 -0
  66. examples/_openaisdk//346/226/207/344/273/266/351/227/256/347/255/224.py +36 -0
  67. examples/_openaisdk//346/226/207/346/241/243/350/247/243/346/236/220.py +34 -0
  68. examples/_openaisdk//346/250/241/345/236/213/346/265/213/350/257/225.py +53 -0
  69. examples/_openaisdk//351/230/277/351/207/214.py +80 -0
  70. {meutils/serving/jina/__demo → examples/ann}/__init__.py +1 -1
  71. examples/ann/main.py +31 -0
  72. examples/apis/kl.py +28 -0
  73. examples/apis/x.py +17 -0
  74. examples/apis/xx.py +17 -0
  75. examples/arq_demo/demo.py +3 -0
  76. examples/backgroundtasks.py +25 -0
  77. examples/bserver.py +513 -21
  78. examples/cache_demo/HermesCache_demo.py +81 -0
  79. examples/cache_demo/acacge.py +26 -0
  80. examples/cache_demo/x.py +31 -0
  81. {meutils/docarray_utils → examples/caches}/__init__.py +1 -1
  82. examples/caches/llmcache.py +18 -0
  83. examples/celery_demo/product_task.py +2 -0
  84. examples/demo.py +17 -1
  85. examples/fastapi_caching.py +59 -0
  86. {meutils/dependencies → examples/gr}/__init__.py +1 -1
  87. examples/gr/d.py +22 -0
  88. examples/gr/demo.py +30 -0
  89. examples/ip2/345/234/260/345/214/272.py +16 -0
  90. examples/jinja2_demo/j2_demo.py +20 -1
  91. examples/json/346/240/207/345/207/206/345/214/226.py +54 -0
  92. examples/md.py +29 -0
  93. {meutils/serving/jina → examples/nesc}/__init__.py +1 -1
  94. examples/nesc/main.py +76 -0
  95. examples/orm/mysql_orm.py +113 -0
  96. examples/orm/sql_creater.py +57 -0
  97. examples/orm/sqlm.py +134 -0
  98. examples/rq_demo/fns.py +18 -0
  99. examples/rq_demo/redis/351/230/237/345/210/227.py +14 -7
  100. examples/rq_demo/redis/351/230/237/345/210/227_add_chatfire.py +30 -0
  101. examples/size_map.py +43 -0
  102. examples/test.py +59 -0
  103. examples/webs/__init__.py +11 -0
  104. examples/webs/main.py +34 -0
  105. examples/x.py +13 -0
  106. examples//345/216/273/346/260/264/345/215/260.py +20 -0
  107. examples//346/226/207/346/241/243/346/231/272/350/203/275/__init__.py +11 -0
  108. meutils/_utils.py +15 -6
  109. meutils/ai_audio/asr/__init__.py +3 -2
  110. meutils/ai_audio/asr/cf_asr.py +53 -0
  111. meutils/ai_audio/asr/de.py +11 -0
  112. meutils/ai_audio/asr/fast_asr.py +15 -7
  113. meutils/ai_audio/asr/openai_asr.py +83 -6
  114. meutils/ai_audio/fast_asr.py +8 -4
  115. meutils/ai_audio/tts/EdgeTTS.py +33 -7
  116. meutils/ai_audio/tts/openai_tts.py +24 -20
  117. meutils/ai_audio/tts/tts_ui.py +1 -0
  118. meutils/ai_audio/utils.py +9 -0
  119. meutils/ai_cv/__init__.py +0 -1
  120. meutils/ai_cv/ocr.py +3 -2
  121. meutils/ai_cv/utils.py +154 -0
  122. meutils/ai_video/avmerge.py +6 -0
  123. meutils/ai_video/video.py +11 -2
  124. meutils/{api → apis}/__init__.py +1 -1
  125. meutils/apis/ali_apis.py +60 -0
  126. meutils/apis/audio/__init__.py +10 -0
  127. meutils/apis/audio/deepinfra.py +59 -0
  128. meutils/apis/audio/fish.py +248 -0
  129. meutils/apis/baidu/__init__.py +9 -0
  130. meutils/apis/baidu/bdaitpzs.py +229 -0
  131. meutils/apis/baidu/test.py +78 -0
  132. meutils/apis/chatglm/__init__.py +11 -0
  133. meutils/apis/chatglm/glm_video.py +273 -0
  134. meutils/apis/chatglm/glm_video_api.py +116 -0
  135. meutils/apis/chatglm/images.py +63 -0
  136. meutils/apis/chatglm/temp.py +259 -0
  137. meutils/apis/chatglm/x.py +31 -0
  138. meutils/{api → apis}/common.py +10 -6
  139. meutils/apis/fal/__init__.py +11 -0
  140. meutils/apis/fal/files.py +53 -0
  141. meutils/apis/fal/images.py +57 -0
  142. meutils/apis/fal/images_.py +72 -0
  143. meutils/apis/fal/videos.py +77 -0
  144. meutils/apis/firecrawl.py +45 -0
  145. meutils/apis/gitee/__init__.py +11 -0
  146. meutils/apis/gitee/images/__init__.py +9 -0
  147. meutils/apis/gitee/images/kolors.py +99 -0
  148. meutils/apis/hailuoai/__init__.py +11 -0
  149. meutils/apis/hailuoai/demo.py +34 -0
  150. meutils/apis/hailuoai/hasha_new.py +248 -0
  151. meutils/apis/hailuoai/music.py +11 -0
  152. meutils/apis/hailuoai/upload.py +116 -0
  153. meutils/apis/hailuoai/videos.py +460 -0
  154. meutils/apis/hailuoai/yy.py +242 -0
  155. meutils/apis/hf/__init__.py +11 -0
  156. meutils/apis/hf/got_ocr.py +64 -0
  157. meutils/apis/hf/gradio.py +34 -0
  158. meutils/apis/hf/hivisionidphotos.py +80 -0
  159. meutils/apis/hf/kolors.py +68 -0
  160. meutils/apis/hf/kolors_virtual_try_on.py +107 -0
  161. meutils/apis/hf/r.py +53 -0
  162. meutils/apis/hf/x.py +26 -0
  163. meutils/apis/hf//350/257/201/344/273/266/347/205/247.py +41 -0
  164. meutils/apis/hunyuan/__init__.py +11 -0
  165. meutils/apis/hunyuan/image_tools.py +84 -0
  166. meutils/apis/images/__init__.py +11 -0
  167. meutils/apis/images/deepinfra.py +92 -0
  168. meutils/apis/images/demo.py +150 -0
  169. meutils/apis/images/eidt.py +36 -0
  170. meutils/apis/images/flux/__init__.py +11 -0
  171. meutils/apis/images/flux/fluxpro.py +108 -0
  172. meutils/apis/images/flux/mystic.py +116 -0
  173. meutils/apis/images/ideogram/__init__.py +10 -0
  174. meutils/apis/images/ideogram/ideogram_images.py +193 -0
  175. meutils/apis/images/prodia/__init__.py +12 -0
  176. meutils/apis/images/prodia/faceswap.py +76 -0
  177. meutils/apis/images/recraft.py +152 -0
  178. meutils/apis/images/virtual_try_on/__init__.py +11 -0
  179. meutils/apis/images/virtual_try_on/images.py +65 -0
  180. meutils/apis/jiema/24mail.py +96 -0
  181. meutils/apis/jiema/__init__.py +11 -0
  182. meutils/apis/jiema/yezi.py +97 -0
  183. meutils/apis/jimeng/__init__.py +11 -0
  184. meutils/apis/jimeng/common.py +328 -0
  185. meutils/apis/jimeng/doubao.py +68 -0
  186. meutils/apis/jimeng/doubao_utils.py +175 -0
  187. meutils/apis/jimeng/files.py +263 -0
  188. meutils/apis/jimeng/images.py +140 -0
  189. meutils/apis/jimeng/lip_sync.py +11 -0
  190. meutils/apis/jina.py +55 -0
  191. meutils/apis/kling/__init__.py +11 -0
  192. meutils/apis/kling/api.py +60 -0
  193. meutils/apis/kling/images.py +174 -0
  194. meutils/apis/kling/kolors_virtual_try_on.py +111 -0
  195. meutils/apis/kling/kolors_virtual_try_on_web.py +126 -0
  196. meutils/apis/kling/videos.py +67 -0
  197. meutils/apis/kling//351/211/264/346/235/203.py +34 -0
  198. meutils/apis/kuaidi.py +32 -0
  199. meutils/apis/kuaishou/__init__.py +10 -0
  200. meutils/apis/kuaishou/klingai.py +523 -0
  201. meutils/apis/kuaishou/klingai_video.py +197 -0
  202. meutils/apis/kuaishou/kolors.py +189 -0
  203. meutils/apis/llm_qa.py +55 -0
  204. meutils/apis/luma/__init__.py +11 -0
  205. meutils/apis/luma/luma.py +123 -0
  206. meutils/apis/minicpm/__init__.py +9 -0
  207. meutils/apis/minicpm/luca.py +137 -0
  208. meutils/apis/monica/__init__.py +11 -0
  209. meutils/apis/monica/llm.py +11 -0
  210. meutils/apis/napkin/__init__.py +11 -0
  211. meutils/apis/napkin/icons.py +42 -0
  212. meutils/apis/niutrans.py +73 -0
  213. meutils/apis/oneapi/__init__.py +11 -0
  214. meutils/apis/oneapi/channel.py +68 -0
  215. meutils/apis/oneapi/common.py +135 -0
  216. meutils/apis/oneapi/log.py +47 -0
  217. meutils/apis/oneapi/token.py +48 -0
  218. meutils/apis/oneapi/token_.py +112 -0
  219. meutils/apis/oneapi/user.py +100 -0
  220. meutils/apis/oneapi/utils.py +47 -0
  221. meutils/apis/pixverse/__init__.py +11 -0
  222. meutils/apis/pixverse/pixverse.py +150 -0
  223. meutils/apis/proxy/__init__.py +11 -0
  224. meutils/apis/proxy/ips.py +178 -0
  225. meutils/apis/remini/__init__.py +11 -0
  226. meutils/apis/remini/remini.py +89 -0
  227. meutils/apis/replicateai/__init__.py +11 -0
  228. meutils/apis/replicateai/images.py +79 -0
  229. meutils/apis/replicateai/raw.py +53 -0
  230. meutils/apis/runwayml/__init__.py +10 -0
  231. meutils/apis/runwayml/gen.py +143 -0
  232. meutils/apis/search/__init__.py +11 -0
  233. meutils/apis/search/baichuan.py +11 -0
  234. meutils/apis/search/metaso.py +218 -0
  235. meutils/apis/search/metaso_.py +77 -0
  236. meutils/apis/search/n.py +99 -0
  237. meutils/apis/search/searxng.py +42 -0
  238. meutils/apis/search_music.py +39 -0
  239. meutils/apis/siliconflow/__init__.py +9 -0
  240. meutils/apis/siliconflow/audio.py +63 -0
  241. meutils/apis/siliconflow/image_to_image.py +116 -0
  242. meutils/apis/siliconflow/images.py +154 -0
  243. meutils/apis/siliconflow/rerankers.py +40 -0
  244. meutils/apis/siliconflow/text_to_image.py +132 -0
  245. meutils/apis/siliconflow/utils.py +66 -0
  246. meutils/apis/siliconflow/videos.py +102 -0
  247. meutils/apis/sunoai/__init__.py +10 -0
  248. meutils/apis/sunoai/haimian.py +135 -0
  249. meutils/apis/sunoai/suno.py +373 -0
  250. meutils/apis/textcard/__init__.py +11 -0
  251. meutils/apis/textcard/demo.py +25 -0
  252. meutils/apis/textcard/hanyuxinjie.py +81 -0
  253. meutils/apis/textin.py +159 -0
  254. meutils/apis/to_image/__init__.py +11 -0
  255. meutils/apis/to_image/html2image.py +29 -0
  256. meutils/apis/to_image/md.py +29 -0
  257. meutils/apis/to_image/url2image.py +41 -0
  258. meutils/apis/together/__init__.py +11 -0
  259. meutils/apis/together/images.py +80 -0
  260. meutils/apis/translator/__init__.py +9 -0
  261. meutils/apis/translator/deeplx.py +55 -0
  262. meutils/apis/tripo3d/__init__.py +11 -0
  263. meutils/apis/tripo3d/images.py +106 -0
  264. meutils/apis/ts.py +60 -0
  265. meutils/apis/uptime_kuma/__init__.py +11 -0
  266. meutils/apis/uptime_kuma/common.py +56 -0
  267. meutils/apis/uptime_kuma//345/233/275/344/272/247/345/210/206/347/273/204.py +68 -0
  268. meutils/apis/utils.py +47 -0
  269. meutils/apis/videos/__init__.py +11 -0
  270. meutils/apis/videos/sora.py +16 -0
  271. meutils/apis/vidu/__init__.py +9 -0
  272. meutils/apis/vidu/vidu_video.py +254 -0
  273. meutils/apis/vidu/x.py +14 -0
  274. meutils/apis/voice_clone/__init__.py +10 -0
  275. meutils/apis/voice_clone/fish.py +236 -0
  276. meutils/apis/voice_clone/fish_api.py +16 -0
  277. meutils/apis/web_search.py +31 -0
  278. meutils/apis/yezi.py +97 -0
  279. meutils/async_task/__init__.py +13 -0
  280. meutils/async_task/celery_config.py +106 -0
  281. meutils/async_task/common.py +37 -0
  282. meutils/async_task/demo_create_tasks.py +73 -0
  283. meutils/async_task/tasks/__init__.py +11 -0
  284. meutils/async_task/tasks/_all.py +20 -0
  285. meutils/async_task/tasks/hailuo.py +24 -0
  286. meutils/async_task/tasks/kling.py +30 -0
  287. meutils/async_task/tasks/replicateai.py +24 -0
  288. meutils/async_task/tasks/test.py +124 -0
  289. meutils/async_task/tasks/vidu.py +28 -0
  290. meutils/async_task/utils.py +191 -0
  291. meutils/async_task//351/200/232/347/224/250/350/256/276/350/256/241.py +119 -0
  292. meutils/async_utils/asyncer_.py +37 -0
  293. meutils/async_utils/background.py +68 -0
  294. meutils/async_utils/common.py +136 -16
  295. meutils/async_utils/test.py +47 -0
  296. meutils/cache_utils.py +29 -23
  297. meutils/caches/__init__.py +9 -0
  298. meutils/caches/acache.py +45 -0
  299. meutils/caches/redis_cache.py +63 -0
  300. meutils/clis/check_api.py +66 -0
  301. meutils/clis/cli.py +1 -1
  302. meutils/common.py +56 -17
  303. meutils/config_utils/__init__.py +11 -0
  304. meutils/config_utils/lark_utils/__init__.py +11 -0
  305. meutils/config_utils/lark_utils/common.py +385 -0
  306. meutils/config_utils/lark_utils/demo.py +13 -0
  307. meutils/config_utils/lark_utils/x.py +50 -0
  308. meutils/config_utils/manager.py +108 -0
  309. meutils/crawlers/__init__.py +11 -0
  310. meutils/data/VERSION +1 -1
  311. meutils/data/cowboy-hat-face.webp +0 -0
  312. meutils/data/oneapi/FOOTER.md +7 -0
  313. meutils/data/oneapi/NOTICE.md +138 -0
  314. meutils/data/oneapi/__init__.py +15 -0
  315. meutils/db/orm.py +179 -0
  316. meutils/db/redis_db.py +87 -0
  317. meutils/decorators/cache.py +1 -1
  318. meutils/decorators/common.py +84 -5
  319. meutils/decorators/contextmanagers.py +17 -6
  320. meutils/decorators/fastapi_decorator.py +77 -3
  321. meutils/decorators/polling.py +46 -0
  322. meutils/decorators/retry.py +150 -26
  323. meutils/fastapi_utils/__init__.py +11 -0
  324. meutils/fastapi_utils/exceptions/http_error.py +72 -0
  325. meutils/fastapi_utils/exceptions/validation_error.py +44 -0
  326. meutils/hash_utils.py +9 -4
  327. meutils/hooks/__init__.py +11 -0
  328. meutils/hooks/hook_test.py +174 -0
  329. meutils/hooks/wechat.py +162 -0
  330. meutils/hooks/wechat_channel.py +303 -0
  331. meutils/init/evn.py +1 -1
  332. meutils/io/files_utils.py +232 -0
  333. meutils/io/image.py +148 -10
  334. meutils/io/x.py +75 -0
  335. meutils/llm/__init__.py +10 -0
  336. meutils/llm/check_api.py +109 -0
  337. meutils/llm/check_utils.py +106 -0
  338. meutils/llm/clients.py +38 -0
  339. meutils/llm/completions/__init__.py +11 -0
  340. meutils/llm/completions/agents/__init__.py +11 -0
  341. meutils/llm/completions/agents/file.py +125 -0
  342. meutils/llm/completions/cp.py +112 -0
  343. meutils/llm/completions/delilegal.py +135 -0
  344. meutils/llm/completions/dify.py +81 -0
  345. meutils/llm/completions/kimi.py +47 -0
  346. meutils/llm/completions/modelscope.py +11 -0
  347. meutils/{fileparser/filetype.py → llm/completions/oi.py} +5 -3
  348. meutils/llm/completions/rag/__init__.py +11 -0
  349. meutils/llm/completions/rag/fire.py +157 -0
  350. meutils/llm/completions/rag/qwen.py +11 -0
  351. meutils/llm/completions/rag/rag.py +41 -0
  352. meutils/llm/completions/rag.py +38 -0
  353. meutils/llm/completions/tryblend.py +201 -0
  354. meutils/llm/completions/tune.py +284 -0
  355. meutils/llm/completions/x.py +26 -0
  356. meutils/llm/completions/xx.py +61 -0
  357. meutils/llm/completions/yuanbao.py +176 -0
  358. meutils/llm/demo.py +114 -0
  359. meutils/llm/functions/__init__.py +11 -0
  360. meutils/llm/mappers.py +15 -0
  361. meutils/llm/openai_utils/__init__.py +11 -0
  362. meutils/llm/openai_utils/common.py +284 -0
  363. meutils/llm/openai_utils/tool_outputs.py +45 -0
  364. meutils/llm/output_parsers/__init__.py +80 -0
  365. meutils/llm/prompts/__init__.py +244 -0
  366. meutils/llm/prompts/demo.py +155 -0
  367. meutils/llm/prompts/html2image_test.py +19 -0
  368. meutils/llm/utils.py +133 -0
  369. meutils/llm/x.py +75 -0
  370. meutils/notice/feishu.py +40 -9
  371. meutils/notice/wechat.py +23 -21
  372. meutils/np_utils.py +10 -1
  373. meutils/office_automation/pdf.py +6 -1
  374. meutils/oss/__init__.py +20 -0
  375. meutils/oss/minio_oss.py +184 -0
  376. meutils/oss/minio_utils.py +48 -0
  377. meutils/other/__demo.py +6 -4
  378. meutils/pandas_utils/__init__.py +1 -0
  379. meutils/pandas_utils/common.py +31 -0
  380. meutils/pandas_utils/pd_utils.py +10 -6
  381. meutils/parsers/__init__.py +10 -0
  382. meutils/parsers/file_parsers.py +110 -0
  383. meutils/parsers/fileparser/demo.py +41 -0
  384. meutils/parsers/fileparser/filetype.py +41 -0
  385. meutils/pay.py +37 -0
  386. meutils/pipe.py +37 -4
  387. meutils/playwright_utils/common.py +20 -12
  388. meutils/plots/common.py +35 -34
  389. meutils/queues/demo.py +56 -0
  390. meutils/queues/smooth_queue.py +120 -0
  391. meutils/queues/uniform_queue.py +3 -1
  392. meutils/request_utils/__init__.py +26 -2
  393. meutils/request_utils/ark.py +47 -0
  394. meutils/request_utils/crawler.py +34 -5
  395. meutils/request_utils/jwt_utils/__init__.py +11 -0
  396. meutils/request_utils/jwt_utils/common.py +42 -0
  397. meutils/request_utils/volc.py +160 -0
  398. meutils/schemas/__init__.py +0 -1
  399. meutils/schemas/baidu_types.py +70 -0
  400. meutils/schemas/batch_types.py +450 -0
  401. meutils/schemas/celery_types.py +64 -0
  402. meutils/schemas/chatfire_types.py +15 -0
  403. meutils/schemas/chatglm_types.py +197 -0
  404. meutils/schemas/db/__init__.py +11 -0
  405. meutils/schemas/db/oneapi_types.py +117 -0
  406. meutils/schemas/dify_types.py +40 -0
  407. meutils/schemas/embedding.py +31 -0
  408. meutils/schemas/fal_types.py +13 -0
  409. meutils/schemas/fish_types.py +11 -0
  410. meutils/schemas/hailuo_types.py +208 -0
  411. meutils/schemas/haimian_types.py +51 -0
  412. meutils/schemas/idphoto_types.py +43 -0
  413. meutils/schemas/image_types.py +476 -0
  414. meutils/schemas/jimeng_types.py +28 -0
  415. meutils/schemas/jina_types.py +67 -0
  416. meutils/schemas/kimi_types.py +86 -0
  417. meutils/schemas/kling_types.py +235 -0
  418. meutils/schemas/kuaishou_types.py +328 -0
  419. meutils/schemas/luma_types.py +59 -0
  420. meutils/schemas/message_types.py +165 -0
  421. meutils/schemas/message_types_.py +219 -0
  422. meutils/schemas/metaso_types.py +64 -0
  423. meutils/schemas/napkin_types.py +85 -0
  424. meutils/schemas/ocr_types.py +37 -0
  425. meutils/schemas/oneapi/__init__.py +11 -0
  426. meutils/schemas/oneapi/_types.py +49 -0
  427. meutils/schemas/oneapi/common.py +883 -0
  428. meutils/schemas/oneapi/icons.py +30 -0
  429. meutils/schemas/oneapi/model_group_info.py +48 -0
  430. meutils/schemas/oneapi/model_info.py +34 -0
  431. meutils/schemas/oneapi/models.py +26 -0
  432. meutils/schemas/oneapi/x.py +26 -0
  433. meutils/schemas/oneapi//351/207/215/345/256/232/345/220/221.py +132 -0
  434. meutils/schemas/openai_api_protocol.py +411 -0
  435. meutils/schemas/openai_types.py +366 -0
  436. meutils/schemas/pixverse_types.py +88 -0
  437. meutils/schemas/playwright_types.py +57 -0
  438. meutils/schemas/prodia_types.py +19 -0
  439. meutils/schemas/replicate_types.py +112 -0
  440. meutils/schemas/request_types.py +20 -0
  441. meutils/schemas/runwayml_types.py +190 -0
  442. meutils/schemas/siliconflow_types.py +80 -0
  443. meutils/schemas/step_types.py +19 -0
  444. meutils/schemas/suno_types.py +319 -0
  445. meutils/schemas/task_types.py +192 -0
  446. meutils/schemas/translator_types.py +29 -0
  447. meutils/schemas/tripo3d_types.py +57 -0
  448. meutils/schemas/tryblend_types.py +51 -0
  449. meutils/schemas/video_types.py +62 -0
  450. meutils/schemas/vidu_types.py +350 -0
  451. meutils/schemas/wechat_types.py +316 -0
  452. meutils/schemas/yuanbao_types.py +260 -0
  453. meutils/serving/celery/__init__.py +8 -0
  454. meutils/serving/celery/config.py +115 -0
  455. meutils/serving/celery/router.py +4 -6
  456. meutils/serving/celery/tasks.py +6 -4
  457. meutils/serving/celery//351/200/232/347/224/250/350/256/276/350/256/241.py +119 -0
  458. meutils/serving/fastapi/common.py +27 -31
  459. meutils/serving/fastapi/dependencies/__init__.py +0 -1
  460. meutils/serving/fastapi/dependencies/auth.py +55 -2
  461. meutils/serving/fastapi/exceptions/http_error.py +67 -2
  462. meutils/serving/fastapi/exceptions/validation_error.py +18 -2
  463. meutils/serving/fastapi/lifespans.py +73 -0
  464. meutils/serving/fastapi/routers/scheduler.py +12 -0
  465. meutils/serving/fastapi/routers/screenshot.py +47 -0
  466. meutils/serving/fastapi/routers/spider.py +8 -3
  467. meutils/serving/fastapi/routers/task.py +48 -0
  468. meutils/serving/fastapi/utils.py +48 -1
  469. meutils/serving/streamlit/common.py +1 -1
  470. meutils/smooth_utils.py +3 -0
  471. meutils/str_utils/__init__.py +22 -3
  472. meutils/str_utils/json_utils.py +7 -0
  473. meutils/str_utils/regular_expression.py +102 -10
  474. meutils/templates/xx.html +21 -0
  475. meutils/templates/xxx.html +117 -0
  476. meutils/todo.py +12 -0
  477. meutils/tools/token_monitor.py +33 -0
  478. MeUtils-2024.3.4.13.4.45.dist-info/RECORD +0 -540
  479. meutils/ai_audio/asr/subtitle.srt +0 -40
  480. meutils/ai_audio/demo.ipynb +0 -1215
  481. meutils/ai_audio/example.srt +0 -348
  482. meutils/ai_audio/new.srt +0 -179
  483. meutils/ai_audio/subtitles.srt +0 -696
  484. meutils/ai_audio/tts/new.srt +0 -179
  485. meutils/ai_audio//350/247/206/351/242/221/345/220/210/345/271/266.sh +0 -32
  486. meutils/ai_cv/1.jpg +0 -0
  487. meutils/ai_cv/197.jpg +0 -0
  488. meutils/ai_cv/2.jpg +0 -0
  489. meutils/ai_cv/img.png +0 -0
  490. meutils/ai_cv/invoice.jpg +0 -0
  491. meutils/ai_cv/tbl.png +0 -0
  492. meutils/ai_cv/test.png +0 -0
  493. meutils/ann/README.md +0 -33
  494. meutils/ann/README_gensim.md +0 -47
  495. meutils/ann/examples/client.py +0 -59
  496. meutils/ann/examples/demo.py +0 -24
  497. meutils/api/deeplx.py +0 -29
  498. meutils/api/qr.png +0 -0
  499. meutils/clis/README.md +0 -29
  500. meutils/clis/__test.sh +0 -17
  501. meutils/clis/deepseek.txt +0 -8
  502. meutils/clis/deepseek_13003330042.json +0 -1
  503. meutils/clis/deepseek_13003872192.json +0 -1
  504. meutils/clis/deepseek_13852263862.json +0 -1
  505. meutils/clis/deepseek_13913898681.json +0 -1
  506. meutils/clis/deepseek_13962978617.json +0 -1
  507. meutils/clis/deepseek_15251801790.json +0 -1
  508. meutils/clis/deepseek_15720826383.json +0 -1
  509. meutils/clis/deepseek_18395563611.json +0 -1
  510. meutils/clis/deepseek_313303303@qq.com.json +0 -1
  511. meutils/clis/kimi_state.json +0 -1
  512. meutils/cmds/README.md +0 -55
  513. meutils/coding/__init__.py +0 -11
  514. meutils/coding/find132.py +0 -40
  515. meutils/db/README.md +0 -51
  516. meutils/decorators/README.md +0 -17
  517. meutils/docarray_utils/demo_es.py +0 -34
  518. meutils/docarray_utils/demo_hnsw.py +0 -55
  519. meutils/docarray_utils/in_memory.py +0 -38
  520. meutils/docarray_utils//346/224/271/351/200/240/344/270/213hnsw.py +0 -43
  521. meutils/io/file.py +0 -20
  522. meutils/io/img.png +0 -0
  523. meutils/io/x.yml +0 -1
  524. meutils/notice/img.png +0 -0
  525. meutils/notice/todo.md +0 -10
  526. 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
  527. meutils/playwright_utils/__test.sh +0 -2
  528. meutils/playwright_utils/kimi1_cookies.json +0 -1
  529. meutils/playwright_utils/kimi2_cookies.json +0 -1
  530. meutils/playwright_utils/kimi_cookies.json +0 -93
  531. meutils/serving/README.md +0 -1
  532. meutils/serving/celery/_run.sh +0 -10
  533. meutils/serving/gui/run.sh +0 -9
  534. meutils/serving/jina/__demo/client.py +0 -42
  535. meutils/serving/jina/__demo/flow.svg +0 -1
  536. meutils/serving/jina/__demo/s.py +0 -34
  537. meutils/serving/jina/__demo/s2.py +0 -37
  538. meutils/serving/jina/__demo/server.py +0 -83
  539. meutils/serving/jina/__demo/test.py +0 -40
  540. meutils/serving/jina/executors/SentenceEncoder.py +0 -62
  541. meutils/serving/jina/executors/SentenceEncoder_.py +0 -63
  542. meutils/serving/jina/executors/__init__.py +0 -46
  543. meutils/serving/jina/executors/base.py +0 -40
  544. meutils/serving/jina/nlp_serving/__init__.py +0 -11
  545. meutils/serving/jina/nlp_serving/word_segmentation.py +0 -40
  546. meutils/serving/streamlit/conf.yaml +0 -5
  547. meutils/serving/streamlit/ocr.png +0 -0
  548. meutils/serving/streamlit/run.sh +0 -17
  549. meutils/serving/webui/.streamlit/_config.toml +0 -186
  550. meutils/serving/webui/.streamlit/config.toml +0 -26
  551. meutils/serving/webui/pages/_1_/345/210/206/350/257/215.py +0 -56
  552. 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
  553. meutils/serving/webui/pages/_3_/346/226/207/346/234/254/345/214/271/351/205/215.py +0 -64
  554. meutils/serving/webui/run.sh +0 -9
  555. meutils/spark/__init__.py +0 -26
  556. meutils/tools/monitor.yml +0 -29
  557. {MeUtils-2024.3.4.13.4.45.dist-info → MeUtils-2025.1.16.17.15.52.dist-info}/LICENSE +0 -0
  558. {MeUtils-2024.3.4.13.4.45.dist-info → MeUtils-2025.1.16.17.15.52.dist-info}/top_level.txt +0 -0
  559. {meutils → examples}/comp_utils/__init__.py +0 -0
  560. {meutils → examples}/comp_utils/reverse_metric.py +0 -0
  561. /meutils/{fileparser/README.md → fastapi_utils/exceptions/__init__.py} +0 -0
  562. /meutils/{fileparser → parsers/fileparser}/PDF/346/212/275/345/217/226.py" +0 -0
  563. /meutils/{fileparser → parsers/fileparser}/__init__.py +0 -0
  564. /meutils/{fileparser → parsers/fileparser}/common.py +0 -0
  565. /meutils/{fileparser → parsers/fileparser}/filetype/__init__.py +0 -0
  566. /meutils/{fileparser → parsers/fileparser}/filetype/__main__.py +0 -0
  567. /meutils/{fileparser → parsers/fileparser}/filetype/filetype.py +0 -0
  568. /meutils/{fileparser → parsers/fileparser}/filetype/helpers.py +0 -0
  569. /meutils/{fileparser → parsers/fileparser}/filetype/match.py +0 -0
  570. /meutils/{fileparser → parsers/fileparser}/filetype/types/__init__.py +0 -0
  571. /meutils/{fileparser → parsers/fileparser}/filetype/types/application.py +0 -0
  572. /meutils/{fileparser → parsers/fileparser}/filetype/types/archive.py +0 -0
  573. /meutils/{fileparser → parsers/fileparser}/filetype/types/audio.py +0 -0
  574. /meutils/{fileparser → parsers/fileparser}/filetype/types/base.py +0 -0
  575. /meutils/{fileparser → parsers/fileparser}/filetype/types/document.py +0 -0
  576. /meutils/{fileparser → parsers/fileparser}/filetype/types/font.py +0 -0
  577. /meutils/{fileparser → parsers/fileparser}/filetype/types/image.py +0 -0
  578. /meutils/{fileparser → parsers/fileparser}/filetype/types/isobmff.py +0 -0
  579. /meutils/{fileparser → parsers/fileparser}/filetype/types/video.py +0 -0
  580. /meutils/{fileparser → parsers/fileparser}/filetype/utils.py +0 -0
  581. /meutils/{fileparser → parsers/fileparser}/pdf.py +0 -0
  582. /meutils/{fileparser → parsers/fileparser}//350/241/250/346/240/274/346/212/275/345/217/226.py" +0 -0
@@ -0,0 +1,13 @@
1
+ #!/usr/bin/env python
2
+ # -*- coding: utf-8 -*-
3
+ # @Project : AI. @by PyCharm
4
+ # @File : __init__.py
5
+ # @Time : 2024/11/28 15:28
6
+ # @Author : betterme
7
+ # @WeChat : meutils
8
+ # @Software : PyCharm
9
+ # @Description :
10
+
11
+
12
+ # from meutils.async_task.common import worker, shared_task, AsyncResult, states
13
+ from meutils.async_task.common import *
@@ -0,0 +1,106 @@
1
+ #!/usr/bin/env python
2
+ # -*- coding: utf-8 -*-
3
+ # @Project : AI. @by PyCharm
4
+ # @File : config
5
+ # @Time : 2024/11/28 14:47
6
+ # @Author : betterme
7
+ # @WeChat : meutils
8
+ # @Software : PyCharm
9
+ # @Description :
10
+
11
+ from meutils.pipe import *
12
+ from datetime import timedelta
13
+ from kombu import Exchange, Queue
14
+
15
+ # 基础配置
16
+ broker_url = 'redis://localhost:6379/0' # 消息代理(推荐使用Redis)
17
+ broker_url = os.getenv('REDIS_URL', broker_url)
18
+
19
+ # result_backend = f"redis://localhost:6379/1" # 结果存储
20
+ result_backend = f"{broker_url.replace('/0', '')}/1" # 结果存储
21
+
22
+ # logger.debug(result_backend)
23
+
24
+ # 添加以下配置增加可靠性
25
+ broker_connection_retry = True
26
+ broker_connection_max_retries = 5
27
+ broker_connection_retry_on_startup = True
28
+
29
+ # 时区设置
30
+ enable_utc = False
31
+ timezone = 'Asia/Shanghai'
32
+
33
+ # 任务序列化与反序列化配置
34
+ task_serializer = 'json'
35
+ result_serializer = 'json'
36
+ accept_content = ['json']
37
+
38
+ # 并发配置
39
+ # worker_pool = 'solo' # 工作进程池类型,可选:'prefork'、'eventlet'、'gevent'
40
+ worker_pool_restarts = True
41
+ worker_concurrency = 8 # worker并发数,一般设置为CPU核心数
42
+ worker_prefetch_multiplier = 3 # 预取任务数
43
+ worker_max_tasks_per_child = 256 # 每个worker执行多少个任务后自动重启
44
+
45
+ # 任务队列配置
46
+ task_default_queue = 'default' # 默认队列
47
+ task_queues = (
48
+ Queue('default', Exchange('default'), routing_key='default'),
49
+ Queue('high_priority', Exchange('high_priority'), routing_key='high_priority'),
50
+ Queue('low_priority', Exchange('low_priority'), routing_key='low_priority'),
51
+ )
52
+
53
+ # 任务执行设置
54
+ task_soft_time_limit = 10 * 60 # 任务软超时时间(秒)
55
+ task_time_limit = 2 * task_soft_time_limit # 任务硬超时时间(秒)
56
+
57
+ # 任务重试配置
58
+ task_publish_retry = True # 发布任务失败时重试
59
+ task_publish_retry_policy = {
60
+ 'max_retries': 5, # 最大重试次数
61
+ 'interval_start': 0, # 初始重试等待时间
62
+ 'interval_step': 2, # 重试间隔递增步长
63
+ 'interval_max': 16, # 最大重试间隔
64
+ }
65
+
66
+ # # 任务路由配置
67
+ # task_routes = {
68
+ # 'project.tasks.high_priority_task': {'queue': 'high_priority'},
69
+ # 'project.tasks.low_priority_task': {'queue': 'low_priority'},
70
+ # }
71
+ #
72
+ # # 定时任务配置
73
+ # beat_schedule = {
74
+ # 'task-every-30-seconds': {
75
+ # 'task': 'project.tasks.periodic_task',
76
+ # 'schedule': timedelta(seconds=30),
77
+ # },
78
+ # }
79
+
80
+ # 日志配置
81
+ worker_log_format = '[%(asctime)s: %(levelname)s/%(processName)s] %(message)s'
82
+ worker_task_log_format = '[%(asctime)s: %(levelname)s/%(processName)s] [%(task_name)s(%(task_id)s)] %(message)s'
83
+
84
+ # 性能优化
85
+ task_acks_late = True # 任务执行完成后再确认
86
+ task_reject_on_worker_lost = True # worker异常关闭时任务会被重新分配
87
+ worker_disable_rate_limits = True # 禁用任务频率限制
88
+
89
+ # 结果后端配置
90
+ result_expires = 30 * 24 * 3600 # 结果过期时间(秒)
91
+ result_persistent = True # 结果持久化存储
92
+
93
+ # 任务执行配置
94
+ # task_always_eager = False # 是否立即执行任务(调试用)
95
+
96
+ # 添加任务持久化配置
97
+ celery_task_store_errors_even_if_ignored = True
98
+ celery_task_ignore_result = False # 不忽略结果
99
+ celery_task_track_started = True # 跟踪任务状态
100
+
101
+ # Redis 持久化配置
102
+ broker_transport_options = {
103
+ 'visibility_timeout': 43200, # 12小时
104
+ 'fanout_prefix': True,
105
+ 'fanout_patterns': True,
106
+ }
@@ -0,0 +1,37 @@
1
+ #!/usr/bin/env python
2
+ # -*- coding: utf-8 -*-
3
+ # @Project : AI. @by PyCharm
4
+ # @File : common
5
+ # @Time : 2024/11/28 15:28
6
+ # @Author : betterme
7
+ # @WeChat : meutils
8
+ # @Software : PyCharm
9
+ # @Description :
10
+
11
+ from meutils.pipe import *
12
+ from meutils.decorators.retry import retrying
13
+
14
+ from meutils.async_task import celery_config
15
+
16
+ from celery import Celery, Task, shared_task, states
17
+
18
+
19
+
20
+ worker = Celery()
21
+
22
+ worker.config_from_object(celery_config)
23
+
24
+ worker.conf.update(
25
+ # result_expires=30 * 24 * 60 * 60,
26
+ # enable_utc=False,
27
+ # timezone='Asia/Shanghai',
28
+ task_track_started=True,
29
+ )
30
+
31
+ if __name__ == '__main__':
32
+ print(worker.conf.humanize(with_defaults=False))
33
+
34
+ print(worker.conf.broker_url)
35
+ print(worker.conf.result_backend)
36
+
37
+ print(arun(get_task("59ddf636-3f27-4110-948e-5977c8cbe1b3")))
@@ -0,0 +1,73 @@
1
+ #!/usr/bin/env python
2
+ # -*- coding: utf-8 -*-
3
+ # @Project : AI. @by PyCharm
4
+ # @File : x
5
+ # @Time : 2024/11/28 15:42
6
+ # @Author : betterme
7
+ # @WeChat : meutils
8
+ # @Software : PyCharm
9
+ # @Description :
10
+
11
+ from meutils.pipe import *
12
+
13
+ from meutils.async_task import worker
14
+ from meutils.async_task.tasks import test, kling, hailuo
15
+ from celery.result import AsyncResult
16
+
17
+ # print(worker.conf)
18
+
19
+ # @shared_task(
20
+ # autoretry_for=(Exception,), # 自动重试的异常类型
21
+ # retry_kwargs={
22
+ # 'max_retries': 3, # 最大重试次数
23
+ # 'countdown': 60 # 重试等待时间(秒)
24
+ # },
25
+ # retry_backoff=True, # 启用指数退避
26
+ # retry_backoff_max=600, # 最大退避时间(秒)
27
+ # retry_jitter=True # 添加随机抖动
28
+ # )
29
+ # def my_task():
30
+ # try:
31
+ # # 任务逻辑
32
+ # result = some_operation()
33
+ # return result
34
+ # except Exception as exc:
35
+ # logger.error(f"Task failed: {exc}")
36
+ # raise # 触发自动重试
37
+
38
+
39
+ if __name__ == '__main__':
40
+ # r = test.do_sync_task.apply_async(kwargs={'a': 1, 'b': 2})
41
+ # logger.debug(r.backend)
42
+ # test.ado_sync_task.apply_async(kwargs={'a': 1, 'b': 2})
43
+ # test.ado_sync_task.apply_async(kwargs={'a': 1, 'b': 3})
44
+ # print(AsyncResult("42e191a0-6099-419e-b61d-07bf7e2df2fc").result)
45
+ # result.backend
46
+ # AsyncResult("42e191a0-6099-419e-b61d-07bf7e2df2fc").get()
47
+ # AsyncResult(r.id).result
48
+
49
+ # test.do_pydantic_task.apply_async(kwargs={'request': test.Request()})
50
+
51
+ # test.do_pydantic_task.apply_async(kwargs={"request": {"method": "POST", "url": "测试"}})
52
+
53
+ # print(type(test.do_pydantic_task))
54
+
55
+ # test.do_pydantic_task.apply_async(kwargs={"request": {"method": "POST", "url": "测试"}})
56
+ # test.do_pydantic_task.apply_async(kwargs={"request": {"method": "xx"}})
57
+ # test.do_pydantic_task.apply_async(args=({"method": "xxxxxxx"},))
58
+
59
+ #
60
+ # test.do_task_retrying.apply_async(kwargs={'name': "###do_task_retrying"})
61
+ # test.do_task_retry.apply_async(kwargs={'name': "###do_task_retry"})
62
+ # test.do_task_retry_backoff.apply_async(kwargs={'name': "###do_task_retry_backoff"})
63
+ # test.ado_pydantic_task.apply_async(kwargs={'name': "###do_task_retry_backoff"})
64
+
65
+ test.Request()
66
+ # test.ado_pydantic_task.apply_async(kwargs={"request": None})
67
+
68
+ # test.ado_pydantic_task.apply_async(kwargs={"request": test.Request().model_dump()})
69
+ # test.ado_pydantic_task_2.apply_async(kwargs={"request": test.Request().model_dump()})
70
+
71
+ # kling.create_task.apply_async(kwargs={"request": kling.kolors_virtual_try_on.TryOnRequest().model_dump()})
72
+
73
+ hailuo.create_task.apply_async(kwargs={"request": hailuo.VideoRequest(prompt='a dog').model_dump()})
@@ -0,0 +1,11 @@
1
+ #!/usr/bin/env python
2
+ # -*- coding: utf-8 -*-
3
+ # @Project : AI. @by PyCharm
4
+ # @File : __init__.py
5
+ # @Time : 2024/11/28 16:03
6
+ # @Author : betterme
7
+ # @WeChat : meutils
8
+ # @Software : PyCharm
9
+ # @Description :
10
+
11
+
@@ -0,0 +1,20 @@
1
+ #!/usr/bin/env python
2
+ # -*- coding: utf-8 -*-
3
+ # @Project : AI. @by PyCharm
4
+ # @File : all_tasks
5
+ # @Time : 2024/11/28 17:50
6
+ # @Author : betterme
7
+ # @WeChat : meutils
8
+ # @Software : PyCharm
9
+ # @Description :
10
+
11
+
12
+ # 所有异步任务
13
+ from meutils.pipe import *
14
+ from meutils.async_task import worker
15
+
16
+ for p in get_resolve_path('.', __file__).glob('*'):
17
+
18
+ if (not p.name.startswith('_')) and p.name.endswith('.py'):
19
+ logger.debug(p)
20
+ _ = try_import(f"meutils.async_task.tasks.{p.stem}")
@@ -0,0 +1,24 @@
1
+ #!/usr/bin/env python
2
+ # -*- coding: utf-8 -*-
3
+ # @Project : AI. @by PyCharm
4
+ # @File : hailuo
5
+ # @Time : 2024/12/6 09:05
6
+ # @Author : betterme
7
+ # @WeChat : meutils
8
+ # @Software : PyCharm
9
+ # @Description :
10
+
11
+
12
+ from meutils.async_utils import async_to_sync_pro
13
+ from meutils.async_task import worker, shared_task
14
+ from meutils.apis.hailuoai.videos import VideoRequest, create_task as remote_create_task, get_task
15
+
16
+
17
+ @shared_task(pydantic=True, retry_kwargs={'max_retries': 10, 'countdown': 10})
18
+ @async_to_sync_pro
19
+ async def create_task(request, **kwargs):
20
+ if isinstance(request, dict):
21
+ request = VideoRequest(**request)
22
+
23
+ response = await remote_create_task(request)
24
+ return response.model_dump()
@@ -0,0 +1,30 @@
1
+ #!/usr/bin/env python
2
+ # -*- coding: utf-8 -*-
3
+ # @Project : AI. @by PyCharm
4
+ # @File : kling
5
+ # @Time : 2024/11/28 16:18
6
+ # @Author : betterme
7
+ # @WeChat : meutils
8
+ # @Software : PyCharm
9
+ # @Description : 注册任务
10
+
11
+ from meutils.async_utils import async_to_sync_pro
12
+ from meutils.async_task import worker, shared_task
13
+
14
+ from meutils.apis.kling import kolors_virtual_try_on
15
+
16
+
17
+ @shared_task(pydantic=True, retry_kwargs={'max_retries': 5, 'countdown': 10})
18
+ @async_to_sync_pro
19
+ async def create_task(request: kolors_virtual_try_on.TryOnRequest, **kwargs):
20
+ if isinstance(request, dict):
21
+ request = kolors_virtual_try_on.TryOnRequest(**request)
22
+
23
+ response = await kolors_virtual_try_on.create_task(request)
24
+ return response.model_dump()
25
+
26
+
27
+ if __name__ == '__main__':
28
+ pass
29
+ # create_task.apply_async()
30
+ create_task.apply_async(kwargs={"request": kolors_virtual_try_on.TryOnRequest().model_dump()})
@@ -0,0 +1,24 @@
1
+ #!/usr/bin/env python
2
+ # -*- coding: utf-8 -*-
3
+ # @Project : AI. @by PyCharm
4
+ # @File : replicateai
5
+ # @Time : 2024/11/29 19:08
6
+ # @Author : betterme
7
+ # @WeChat : meutils
8
+ # @Software : PyCharm
9
+ # @Description :
10
+
11
+
12
+ from meutils.pipe import *
13
+ from meutils.async_utils import async_to_sync_pro
14
+ from meutils.decorators.retry import retrying
15
+ from meutils.async_task import worker, shared_task
16
+
17
+ from meutils.apis.replicateai import raw as replicate
18
+
19
+
20
+ @shared_task(pydantic=True, retry_kwargs={'max_retries': 5, 'countdown': 10})
21
+ @async_to_sync_pro
22
+ async def create_task(request: replicate.ReplicateRequest, **kwargs):
23
+ response = await replicate.create_task(request)
24
+ return response
@@ -0,0 +1,124 @@
1
+ #!/usr/bin/env python
2
+ # -*- coding: utf-8 -*-
3
+ # @Project : AI. @by PyCharm
4
+ # @File : kling
5
+ # @Time : 2024/11/28 16:18
6
+ # @Author : betterme
7
+ # @WeChat : meutils
8
+ # @Software : PyCharm
9
+ # @Description :
10
+
11
+ from meutils.pipe import *
12
+ from meutils.decorators.retry import retrying
13
+ from meutils.async_utils import async_to_sync_pro
14
+ from meutils.async_task import worker, shared_task
15
+
16
+
17
+ class Request(BaseModel):
18
+ method: str = "GET"
19
+ url: str = "https://api.chatfire.cn/"
20
+
21
+ class Config:
22
+ frozen = True
23
+
24
+
25
+ @shared_task
26
+ def do_sync_task(sleep=10, **kwargs):
27
+ logger.debug("同步任务")
28
+ time.sleep(sleep)
29
+
30
+ return kwargs
31
+
32
+
33
+ # AttributeError: 'AsyncToSync' object has no attribute '__name__'. Did you mean: '__ne__'?
34
+
35
+
36
+ @alru_cache()
37
+ async def create_task(request: Request, **kwargs):
38
+ logger.debug(request)
39
+ await asyncio.sleep(10)
40
+ return request
41
+
42
+
43
+ worker.task()
44
+
45
+
46
+ @shared_task(pydantic=True)
47
+ @async_to_sync_pro
48
+ async def ado_pydantic_task(request: Request):
49
+ logger.debug("同步任务+协程+结构体+缓存")
50
+ logger.debug(request)
51
+ if isinstance(request, dict):
52
+ request = Request(**request)
53
+
54
+ return await create_task(request)
55
+
56
+
57
+ @worker.task(pydantic=True)
58
+ @async_to_sync_pro
59
+ async def ado_pydantic_task_2(request: Request):
60
+ logger.debug("同步任务+协程+结构体+缓存")
61
+ logger.debug(request)
62
+
63
+ return await create_task(request)
64
+
65
+
66
+ @shared_task(pydantic=True)
67
+ def do_pydantic_task(request: Request) -> Request:
68
+ logger.debug(request)
69
+ return request
70
+
71
+
72
+ @shared_task(retry_kwargs={'max_retries': 10})
73
+ def do_task_retry(*args, **kwargs):
74
+ logger.debug("do_task_retry")
75
+
76
+ return 1 / 0
77
+
78
+
79
+ @shared_task(
80
+ default_retry_delay=3,
81
+ retry_backoff=True,
82
+ retry_kwargs={'max_retries': 10}
83
+ )
84
+ def do_task_retry_backoff_noautoretry(*args, **kwargs):
85
+ logger.debug("do_task_retry_backoff")
86
+
87
+ return 1 / 0
88
+
89
+
90
+ @shared_task(
91
+ autoretry_for=(Exception,),
92
+ default_retry_delay=3,
93
+ retry_backoff=True,
94
+ retry_kwargs={'max_retries': 10}
95
+ )
96
+ def do_task_retry_backoff(*args, **kwargs):
97
+ logger.debug("do_task_retry_backoff autoretry")
98
+
99
+ return 1 / 0
100
+
101
+
102
+ @shared_task(retry_kwargs={'max_retries': 3})
103
+ @retrying(10)
104
+ def do_task_retrying(*args, **kwargs):
105
+ logger.debug("do_task_retrying")
106
+ return 1 / 0
107
+
108
+
109
+ @shared_task
110
+ @retrying(3)
111
+ def proxy_task(**kwargs):
112
+ method = kwargs.pop('method', '')
113
+ url = kwargs.pop('url', '')
114
+
115
+ logger.debug(kwargs)
116
+
117
+ response = requests.request(method, url, **kwargs).json()
118
+
119
+ return response
120
+
121
+
122
+ if __name__ == '__main__':
123
+ # print(do_sync_task.apply_async(kwargs={'a': 1, 'b': 2}))
124
+ print(AsyncToSync)
@@ -0,0 +1,28 @@
1
+ #!/usr/bin/env python
2
+ # -*- coding: utf-8 -*-
3
+ # @Project : AI. @by PyCharm
4
+ # @File : kling
5
+ # @Time : 2024/11/28 16:18
6
+ # @Author : betterme
7
+ # @WeChat : meutils
8
+ # @Software : PyCharm
9
+ # @Description :
10
+
11
+ from meutils.pipe import *
12
+ from meutils.decorators.retry import retrying
13
+ from meutils.async_task import worker, shared_task
14
+
15
+ from meutils.apis.vidu.vidu_video import create_task, get_task, ViduRequest
16
+
17
+
18
+ @shared_task
19
+ async def do_task(**kwargs):
20
+ return create_task(ViduRequest(**kwargs))
21
+
22
+
23
+ @shared_task
24
+ @retrying(3)
25
+ async def proxy_task(**kwargs):
26
+ pass
27
+
28
+ return response
@@ -0,0 +1,191 @@
1
+ #!/usr/bin/env python
2
+ # -*- coding: utf-8 -*-
3
+ # @Project : AI. @by PyCharm
4
+ # @File : utils
5
+ # @Time : 2024/11/29 16:22
6
+ # @Author : betterme
7
+ # @WeChat : meutils
8
+ # @Software : PyCharm
9
+ # @Description : 通用异步设计,兼容oneapi监控
10
+
11
+ from celery.result import AsyncResult
12
+
13
+ from meutils.pipe import *
14
+ from meutils.schemas.task_types import TaskResponse
15
+
16
+ from meutils.db.orm import update_or_insert
17
+ from meutils.schemas.db.oneapi_types import OneapiTask
18
+
19
+ from meutils.db.redis_db import redis_aclient
20
+
21
+ from fastapi import APIRouter, File, UploadFile, Query, Form, Depends, Request, HTTPException, status, BackgroundTasks
22
+
23
+
24
+ async def create_task(async_task, request: Union[BaseModel, dict]):
25
+ if not isinstance(request, dict):
26
+ request = request.model_dump()
27
+
28
+ result = async_task.apply_async(kwargs={"request": request})
29
+ task_id = result.id
30
+
31
+ return TaskResponse(task_id=task_id, request_id=task_id)
32
+
33
+
34
+ # {
35
+ # "code": 0,
36
+ # "message": "SUCCEED",
37
+ # "request_id": "CjMkWmdJhuIAAAAAAAS0mA",
38
+ # "data": {
39
+ # "task_id": "CjMkWmdJhuIAAAAAAAS0mA",
40
+ # "task_status": "submitted",
41
+ # "created_at": 1732881630997,
42
+ # "updated_at": 1732881630997
43
+ # }
44
+ # }
45
+
46
+
47
+ async def get_task(
48
+ task_id: str,
49
+ remote_get_task: Optional[Callable] = None,
50
+ filter_kwargs: Optional[dict] = None,
51
+ background_tasks: Optional[BackgroundTasks] = None,
52
+ ):
53
+ """
54
+
55
+ :param task_id:
56
+ :param remote_get_task:
57
+ :param filter_kwargs: #######参数可以舍弃
58
+ filter_kwargs = {
59
+ "task_id": task_id, #########理论上只需这个
60
+ "user_id": user_id,
61
+ "platform": "replicate",
62
+ "action": "replicate", # 模型
63
+ }
64
+ :return:
65
+ """
66
+ filter_kwargs = filter_kwargs or {}
67
+ filter_kwargs["task_id"] = task_id
68
+
69
+ result = AsyncResult(id=task_id)
70
+ logger.debug(bjson(result._get_task_meta()))
71
+ # logger.debug(bjson(result.get(timeout=30)))
72
+ logger.debug(result)
73
+ logger.debug(result.ready())
74
+ logger.debug(result.state)
75
+
76
+ # if result.status=="PENDING": # worker可能还未启动,会阻塞
77
+ # if await redis_aclient.select(1) and not await redis_aclient.exists(f"celery-task-meta-{task_id}"):
78
+ # raise HTTPException(status_code=404, detail="TaskID not found")
79
+
80
+ if result.ready():
81
+ if result.successful():
82
+ data = result.get(timeout=30).copy() # 创建任务时:remote task的返回结果 ####### copy避免丢失字段
83
+ logger.debug(bjson(data))
84
+ token = data.pop("system_fingerprint", None) # 远程任务 token/apikey
85
+
86
+ remote_task_id = (
87
+ data.get("task_id") # 提前写
88
+ or data.get("data", {}).get("task_id")
89
+ or data.get("data", {}).get("id")
90
+ or data.get("id")
91
+ or data.get("request_id")
92
+ )
93
+
94
+ response = TaskResponse(
95
+ task_id=task_id,
96
+
97
+ message="Task completed successfully",
98
+ status=result.status,
99
+ data=data
100
+ )
101
+
102
+ if remote_get_task:
103
+ if inspect.iscoroutinefunction(remote_get_task):
104
+ remote_task_response = await remote_get_task(remote_task_id, token)
105
+ else:
106
+ remote_task_response = remote_get_task(remote_task_id, token)
107
+
108
+ if not isinstance(remote_task_response, dict):
109
+ remote_task_response = remote_task_response.model_dump()
110
+
111
+ # logger.debug(response.model_dump_json(indent=4))
112
+ # logger.debug(bjson(remote_task_response))
113
+
114
+ _response = {**response.model_dump(), **remote_task_response}
115
+ response = response.construct(**_response)
116
+
117
+ # logger.debug(response.model_dump_json(indent=4))
118
+
119
+ else:
120
+ response = TaskResponse(
121
+ task_id=task_id,
122
+
123
+ code=1,
124
+ message=str(result.result),
125
+ status=result.status,
126
+ )
127
+ else:
128
+ response = TaskResponse(
129
+ task_id=task_id,
130
+
131
+ message="Task is still running",
132
+ status=result.status,
133
+ )
134
+
135
+ # 更新到数据库:异步任务
136
+ update_fn = partial(update_oneapi_from_response, task_response=response)
137
+ if background_tasks:
138
+ background_tasks.add_task(update_or_insert, OneapiTask, filter_kwargs, update_fn)
139
+ else:
140
+ await update_or_insert(OneapiTask, filter_kwargs, update_fn)
141
+
142
+ return response
143
+
144
+
145
+ # todo: 可以设计更通用的
146
+ async def update_oneapi_from_response(task: OneapiTask, task_response: TaskResponse):
147
+ """
148
+
149
+ filter_kwargs = {
150
+ "task_id": task_id,
151
+ "user_id": user_id,
152
+ "platform": "replicate",
153
+ "action": "replicate", # 模型
154
+ }
155
+
156
+ 需要获取这几个信息 user_id
157
+
158
+ """
159
+ # if task.status in {"SUCCESS", "FAILURE"}: return False # 跳出轮询,不再更新
160
+
161
+ task.data = task_response.model_dump(exclude={"system_fingerprint"})
162
+ task.status = task_response.status
163
+ task.progress = time.time() // 10 % 100
164
+
165
+ if task.status == "SUCCESS": ###### todo: 状态对齐
166
+ task.progress = "100%"
167
+ elif task.status == "FAILURE":
168
+ task.fail_reason = "查看详情"
169
+
170
+ task.updated_at = int(time.time())
171
+ task.finish_time = int(time.time()) # 不是实际时间
172
+
173
+
174
+ if __name__ == '__main__':
175
+ from meutils.async_task import worker, shared_task #######重要 需要识别到worker
176
+
177
+ from meutils.apis.kling import kolors_virtual_try_on
178
+ from meutils.async_task.tasks import hailuo
179
+
180
+ task_id = "7d4fbaf3-f641-482b-b02c-ccd30e61195a"
181
+ # filter_kwargs = {
182
+ # "task_id": task_id, #########理论上只需这个
183
+ # "user_id": 1,
184
+ # "platform": "kling",
185
+ # "action": "kling", # 模型
186
+ # }
187
+
188
+ # arun(get_task(task_id, hailuo.get_task))
189
+ #
190
+ # task_id = "e3f76be8-f7eb-4562-a7af-029928d074d5"
191
+ # arun(get_task(task_id, kolors_virtual_try_on.get_task))