2024-08-29 14:21:20 +08:00
<!doctype html>
< html lang = "zh-CN" data-theme = "light" >
< head >
< meta charset = "utf-8" / >
< meta name = "viewport" content = "width=device-width,initial-scale=1" / >
< meta name = "generator" content = "VuePress 2.0.0-rc.9" / >
< meta name = "theme" content = "VuePress Theme Hope 2.0.0-rc.32" / >
< style >
html {
background: var(--bg-color, #fff);
}
html[data-theme="dark"] {
background: var(--bg-color, #1d1e1f);
}
body {
background: var(--bg-color);
}
< / style >
< script >
const userMode = localStorage.getItem("vuepress-theme-hope-scheme");
const systemDarkMode =
window.matchMedia & &
window.matchMedia("(prefers-color-scheme: dark)").matches;
if (userMode === "dark" || (userMode !== "light" & & systemDarkMode)) {
document.documentElement.setAttribute("data-theme", "dark");
}
< / script >
< link rel = "alternate" hreflang = "en-us" href = "https://vuepress-theme-hope-docs-demo.netlify.app/en/dev/api/plugin/load.html" > < meta property = "og:url" content = "https://vuepress-theme-hope-docs-demo.netlify.app/dev/api/plugin/load.html" > < meta property = "og:site_name" content = "LiteyukiBot 轻雪机器人" > < meta property = "og:title" content = "liteyuki.plugin.load" > < meta property = "og:description" content = "func load_plugin() -> Optional[Plugin] 说明: 加载单个插件,可以是本地插件或是通过 pip 安装的插件。 参数: module_path: 插件名称 path.to.your.plugin 或插件路径 pathlib.Path(path/to/your/plugin): 源代码 func load_plugins..." > < meta property = "og:type" content = "article" > < meta property = "og:locale" content = "zh-CN" > < meta property = "og:locale:alternate" content = "en-US" > < meta property = "og:updated_time" content = "2024-08-29T06:19:39.000Z" > < meta property = "article:modified_time" content = "2024-08-29T06:19:39.000Z" > < script type = "application/ld+json" > { "@context" : "https://schema.org" , "@type" : "Article" , "headline" : "liteyuki.plugin.load" , "image" : [ "" ] , "dateModified" : "2024-08-29T06:19:39.000Z" , "author" : [ ] } < / script > < script src = "/js/zh/get_data.js" type = "module" > < / script > < script src = "/js/style.js" type = "module" > < / script > < link rel = "icon" href = "https://cdn.liteyuki.icu/favicon.ico" > < link rel = "stylesheet" href = "https://cdn.bootcdn.net/ajax/libs/firacode/6.2.0/fira_code.min.css" > < meta name = "viewport" content = "width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no" > < title > liteyuki.plugin.load | LiteyukiBot 轻雪机器人< / title > < meta name = "description" content = "func load_plugin() -> Optional[Plugin] 说明: 加载单个插件,可以是本地插件或是通过 pip 安装的插件。 参数: module_path: 插件名称 path.to.your.plugin 或插件路径 pathlib.Path(path/to/your/plugin): 源代码 func load_plugins..." >
< link rel = "preload" href = "/assets/style-DI-mIFA3.css" as = "style" > < link rel = "stylesheet" href = "/assets/style-DI-mIFA3.css" >
2024-08-29 15:51:25 +08:00
< link rel = "modulepreload" href = "/assets/app-BiKNfxRB.js" > < link rel = "modulepreload" href = "/assets/load.html-CCxwqy7a.js" >
< link rel = "prefetch" href = "/assets/index.html-qWOsHxUn.js" as = "script" > < link rel = "prefetch" href = "/assets/index.html-B_uQoPOQ.js" as = "script" > < link rel = "prefetch" href = "/assets/config.html-CghxM6xU.js" as = "script" > < link rel = "prefetch" href = "/assets/fandq.html-BAB4I9r5.js" as = "script" > < link rel = "prefetch" href = "/assets/install.html-B5QS6l5b.js" as = "script" > < link rel = "prefetch" href = "/assets/index.html-CwKgdiha.js" as = "script" > < link rel = "prefetch" href = "/assets/dev_comm.html-SU42FWy3.js" as = "script" > < link rel = "prefetch" href = "/assets/dev_lyfunc.html-DJwUsYB0.js" as = "script" > < link rel = "prefetch" href = "/assets/dev_lyplugin.html-sZFaLFnq.js" as = "script" > < link rel = "prefetch" href = "/assets/dev_resource_pack.html-U-MBXvCa.js" as = "script" > < link rel = "prefetch" href = "/assets/index.html-BtSZzpbi.js" as = "script" > < link rel = "prefetch" href = "/assets/index.html-CGrHG9yW.js" as = "script" > < link rel = "prefetch" href = "/assets/plugin.html-CeS1bUHG.js" as = "script" > < link rel = "prefetch" href = "/assets/resource.html-B66LgAIn.js" as = "script" > < link rel = "prefetch" href = "/assets/index.html-tUVYWHEk.js" as = "script" > < link rel = "prefetch" href = "/assets/agreement.html-BYF2m1hp.js" as = "script" > < link rel = "prefetch" href = "/assets/basic_command.html-BVNt3mAA.js" as = "script" > < link rel = "prefetch" href = "/assets/extra_command.html-BhxUgOoX.js" as = "script" > < link rel = "prefetch" href = "/assets/index.html-pu5qB5WJ.js" as = "script" > < link rel = "prefetch" href = "/assets/config.html-DRx4-bKt.js" as = "script" > < link rel = "prefetch" href = "/assets/exception.html-Dspd5-_b.js" as = "script" > < link rel = "prefetch" href = "/assets/log.html-C-MBMPHN.js" as = "script" > < link rel = "prefetch" href = "/assets/mkdoc.html-jbMCr2yh.js" as = "script" > < link rel = "prefetch" href = "/assets/utils.html-DYmWb8-h.js" as = "script" > < link rel = "prefetch" href = "/assets/index.html-ll56E8IE.js" as = "script" > < link rel = "prefetch" href = "/assets/config.html-DwM8jY8l.js" as = "script" > < link rel = "prefetch" href = "/assets/fandq.html-Db0an3sy.js" as = "script" > < link rel = "prefetch" href = "/assets/install.html-BBZgFfno.js" as = "script" > < link rel = "prefetch" href = "/assets/index.html-Dc3h8igF.js" as = "script" > < link rel = "prefetch" href = "/assets/dev_comm.html-Bl9b55F5.js" as = "script" > < link rel = "prefetch" href = "/assets/dev_lyfunc.html-CrmWGA_A.js" as = "script" > < link rel = "prefetch" href = "/assets/dev_lyplugin.html-Ck2ppBsy.js" as = "script" > < link rel = "prefetch" href = "/assets/dev_resource_pack.html-ruM_kCwY.js" as = "script" > < link rel = "prefetch" href = "/assets/index.html-C3g2A5U7.js" as = "script" > < link rel = "prefetch" href = "/assets/plugin.html-BUUZ0KcH.js" as = "script" > < link rel = "prefetch" href = "/assets/resource.html-DtLVj9H_.js" as = "script" > < link rel = "prefetch" href = "/assets/index.html-BMo3mIHg.js" as = "script" > < link rel = "prefetch" href = "/assets/agreement.html-6_LvudTA.js" as = "script" > < link rel = "prefetch" href = "/assets/basic_command.html-C7yDqPnu.js" as = "script" > < link rel = "prefetch" href = "/assets/extra_command.html-BQhW2l_Z.js" as = "script" > < link rel = "prefetch" href = "/assets/index.html-DKdzkW2G.js" as = "script" > < link rel = "prefetch" href = "/assets/lifespan.html-DKKWaAjl.js" as = "script" > < link rel = "prefetch" href = "/assets/index.html-C4qBL3GU.js" as = "script" > < link rel = "prefetch" href = "/assets/channel.html-B7FAFTjk.js" as = "script" > < link rel = "prefetch" href = "/assets/event.html-Cl4aeV6U.js" as = "script" > < link rel = "prefetch" href = "/assets/rpc.html-Bu3qquT0.js" as = "script" > < link rel = "prefetch" href = "/assets/socks_channel.html-BvWbcicN.js" as = "script" > < link rel = "prefetch" href = "/assets/storage.html-CYcJv9FX.js" as = "script" > < link rel = "prefetch" href = "/assets/index.html-ClLdm0S9.js" as = "script" > < link rel = "prefetch" href = "/assets/manager.html-D5SbrwQV.js" as = "script" > < link rel = "prefetch" href = "/assets/index.html-CRa55Jk5.js" as = "script" > < link rel = "prefetch" href = "/assets/observer.html-BrGRvQmU.js" as = "script" > < link rel = "prefetch" href = "/assets/plugin.html-jL1mmrsH.js" as = "script" > < link rel = "prefetch" href = "/assets/index.html-BZaazPnS.js" as = "script" > < link rel = "prefetch" href = "/assets/event.html-BZCKvMfj.js" as = "script" > < link rel = "prefetch" href = "/assets/matcher.html-B-1fqyad
2024-08-29 14:21:20 +08:00
< / head >
< body >
2024-08-29 15:51:25 +08:00
< div id = "app" > <!-- [ --> <!-- [ --> <!-- [ --> < span tabindex = "-1" > < / span > < a href = "#main-content" class = "vp-skip-link sr-only" > 跳至主要內容< / a > <!-- ] --> < div class = "theme-container has-toc" > <!-- [ --> < header id = "navbar" class = "vp-navbar" > < div class = "vp-navbar-start" > < button type = "button" class = "vp-toggle-sidebar-button" title = "Toggle Sidebar" > < span class = "icon" > < / span > < / button > <!-- [ --> <!-- --> <!-- ] --> <!-- [ --> < a class = "route-link vp-brand" href = "/" > < img class = "vp-nav-logo" src = "https://cdn.liteyuki.icu/static/img/liteyuki_icon_640.png" alt > <!-- --> < span class = "vp-site-name hide-in-pad" > LiteyukiBot 轻雪机器人< / span > < / a > <!-- ] --> <!-- [ --> <!-- --> <!-- ] --> < / div > < div class = "vp-navbar-center" > <!-- [ --> <!-- --> <!-- ] --> <!-- [ --> < nav class = "vp-nav-links" > < div class = "nav-item hide-in-mobile" > < a class = "route-link nav-link" href = "/" aria-label = "首页" > < span class = "font-icon icon fa-fw fa-sm fas fa-home" style = "" > < / span > 首页<!-- --> < / a > < / div > < div class = "nav-item hide-in-mobile" > < a class = "route-link nav-link" href = "/deploy/" aria-label = "安装及部署" > <!-- --> 安装及部署<!-- --> < / a > < / div > < div class = "nav-item hide-in-mobile" > < a class = "route-link nav-link" href = "/usage/" aria-label = "使用及功能" > <!-- --> 使用及功能<!-- --> < / a > < / div > < div class = "nav-item hide-in-mobile" > < a class = "route-link nav-link" href = "/store/" aria-label = "资源及插件" > <!-- --> 资源及插件<!-- --> < / a > < / div > < div class = "nav-item hide-in-mobile" > < a class = "route-link nav-link active" href = "/dev/" aria-label = "开发及贡献" > <!-- --> 开发及贡献<!-- --> < / a > < / div > < / nav > <!-- ] --> <!-- [ --> <!-- --> <!-- ] --> < / div > < div class = "vp-navbar-end" > <!-- [ --> <!-- --> <!-- ] --> <!-- [ --> < div class = "nav-item" > < div class = "dropdown-wrapper i18n-dropdown" > < button type = "button" class = "dropdown-title" aria-label = "选择语言" > <!-- [ --> < svg xmlns = "http://www.w3.org/2000/svg" class = "icon i18n-icon" viewBox = "0 0 1024 1024" fill = "currentColor" aria-label = "i18n icon" style = "width:1rem;height:1rem;vertical-align:middle;" > < path d = "M379.392 460.8 494.08 575.488l-42.496 102.4L307.2 532.48 138.24 701.44l-71.68-72.704L234.496 460.8l-45.056-45.056c-27.136-27.136-51.2-66.56-66.56-108.544h112.64c7.68 14.336 16.896 27.136 26.112 35.84l45.568 46.08 45.056-45.056C382.976 312.32 409.6 247.808 409.6 204.8H0V102.4h256V0h102.4v102.4h256v102.4H512c0 70.144-37.888 161.28-87.04 210.944L378.88 460.8zM576 870.4 512 1024H409.6l256-614.4H768l256 614.4H921.6l-64-153.6H576zM618.496 768h196.608L716.8 532.48 618.496 768z" > < / path > < / svg > <!-- ] --> < span class = "arrow" > < / span > < ul class = "nav-dropdown" > < li class = "dropdown-item" > < a class = "route-link nav-link active" href = "/dev/api/plugin/load.html" aria-label = "简体中文" > <!-- --> 简体中文<!-- --> < / a > < / li > < li class = "dropdown-item" > < a class = "route-link nav-link" href = "/en/dev/api/plugin/load.html" aria-label = "English" > <!-- --> English<!-- --> < / a > < / li > < / ul > < / button > < / div > < / div > < div class = "nav-item vp-repo" > < a class = "vp-repo-link" href = "https://github.com/LiteyukiStudio/LiteyukiBot" target = "_blank" rel = "noopener noreferrer" aria-label = "GitHub" > < svg xmlns = "http://www.w3.org/2000/svg" class = "icon github-icon" viewBox = "0 0 1024 1024" fill = "currentColor" aria-label = "github icon" style = "width:1.25rem;height:1.25rem;vertical-align:middle;" > < path d = "M511.957 21 . 333C241 . 024 21 . 333 21 . 333 240 . 981 21 . 333 512c0 216 . 832 140 . 544 400 . 725 335 . 574 465 . 664 24 . 49 4 . 395 32 . 256-10 . 07 32 . 256-23 . 083 0-11 . 69 . 256-44 . 245 0-85 . 205-136 . 448 29 . 61-164 . 736-64 . 64-164 . 736-64 . 64-22 . 315-56 . 704-54 . 4-71 . 765-54 . 4-71 . 765-44 . 587-30 . 464 3 . 285-29 . 824 3 . 285-29 . 824 49 . 195 3 . 413 75 . 179 50 . 517 75 . 179 50 . 517 43 . 776 75 . 008 114 . 816 53 . 333 142 . 762 40 . 79 4 . 523-31 . 66 17 . 152-53 . 377 31 . 19-65 . 537-108 . 971-12 . 458-223 . 488-54 . 485-223 . 488-242 . 602 0-53 . 547 19 . 114-97 . 323 50 . 517-131 . 67-5 . 035-12 . 33-21 . 93-62 . 293 4 . 779-129 . 834 0 0 41 . 258-13 . 184 134 . 912 50 . 346a469 . 803 469 . 803 0 0 1 122 . 88-16 . 554c41 . 642 . 213 83 . 626 5 . 632 122 . 88 16 . 554 93 . 653-63 . 488 134 . 784-50 . 346 134 . 784-50 . 346 26 . 752 67 . 541 9 . 898 117 . 504 4 . 864 129 . 834 31 . 402 34 . 347 50 . 474 78 . 123 50 . 474 131 . 67 0 188 . 586-114 . 73 230 . 016-224 . 042 242 . 09 17 . 578 15 . 232 33 . 578 44 . 672 33 . 578 90 . 454v135 . 85c0 13
2024-08-29 14:21:20 +08:00
< span class = "token triple-quoted-string string" > " " " 加载单个插件,可以是本地插件或是通过 `pip` 安装的插件。
参数:
module_path: 插件名称 `path.to.your.plugin`
或插件路径 `pathlib.Path(path/to/your/plugin)`
" " " < / span >
module_path < span class = "token operator" > =< / span > path_to_module_name< span class = "token punctuation" > (< / span > Path< span class = "token punctuation" > (< / span > module_path< span class = "token punctuation" > )< / span > < span class = "token punctuation" > )< / span > < span class = "token keyword" > if< / span > < span class = "token builtin" > isinstance< / span > < span class = "token punctuation" > (< / span > module_path< span class = "token punctuation" > ,< / span > Path< span class = "token punctuation" > )< / span > < span class = "token keyword" > else< / span > module_path
< span class = "token keyword" > try< / span > < span class = "token punctuation" > :< / span >
module < span class = "token operator" > =< / span > import_module< span class = "token punctuation" > (< / span > module_path< span class = "token punctuation" > )< / span >
_plugins< span class = "token punctuation" > [< / span > module< span class = "token punctuation" > .< / span > __name__< span class = "token punctuation" > ]< / span > < span class = "token operator" > =< / span > Plugin< span class = "token punctuation" > (< / span > name< span class = "token operator" > =< / span > module< span class = "token punctuation" > .< / span > __name__< span class = "token punctuation" > ,< / span > module< span class = "token operator" > =< / span > module< span class = "token punctuation" > ,< / span > module_name< span class = "token operator" > =< / span > module_path< span class = "token punctuation" > )< / span >
< span class = "token keyword" > if< / span > module< span class = "token punctuation" > .< / span > __dict__< span class = "token punctuation" > .< / span > get< span class = "token punctuation" > (< / span > < span class = "token string" > ' __plugin_metadata__' < / span > < span class = "token punctuation" > ,< / span > < span class = "token boolean" > None< / span > < span class = "token punctuation" > )< / span > < span class = "token punctuation" > :< / span >
metadata< span class = "token punctuation" > :< / span > < span class = "token string" > ' PluginMetadata' < / span > < span class = "token operator" > =< / span > module< span class = "token punctuation" > .< / span > __dict__< span class = "token punctuation" > [< / span > < span class = "token string" > ' __plugin_metadata__' < / span > < span class = "token punctuation" > ]< / span >
display_name < span class = "token operator" > =< / span > module< span class = "token punctuation" > .< / span > __name__< span class = "token punctuation" > .< / span > split< span class = "token punctuation" > (< / span > < span class = "token string" > ' .' < / span > < span class = "token punctuation" > )< / span > < span class = "token punctuation" > [< / span > < span class = "token operator" > -< / span > < span class = "token number" > 1< / span > < span class = "token punctuation" > ]< / span >
< span class = "token keyword" > elif< / span > module< span class = "token punctuation" > .< / span > __dict__< span class = "token punctuation" > .< / span > get< span class = "token punctuation" > (< / span > < span class = "token string" > ' __liteyuki_plugin_meta__' < / span > < span class = "token punctuation" > ,< / span > < span class = "token boolean" > None< / span > < span class = "token punctuation" > )< / span > < span class = "token punctuation" > :< / span >
metadata< span class = "token punctuation" > :< / span > < span class = "token string" > ' PluginMetadata' < / span > < span class = "token operator" > =< / span > module< span class = "token punctuation" > .< / span > __dict__< span class = "token punctuation" > [< / span > < span class = "token string" > ' __liteyuki_plugin_meta__' < / span > < span class = "token punctuation" > ]< / span >
display_name < span class = "token operator" > =< / span > format_display_name< span class = "token punctuation" > (< / span > < span class = "token string-interpolation" > < span class = "token string" > f" < / span > < span class = "token interpolation" > < span class = "token punctuation" > {< / span > metadata< span class = "token punctuation" > .< / span > name< span class = "token punctuation" > }< / span > < / span > < span class = "token string" > (< / span > < span class = "token interpolation" > < span class = "token punctuation" > {< / span > module< span class = "token punctuation" > .< / span > __name__< span class = "token punctuation" > .< / span > split< span class = "token punctuation" > (< / span > < span class = "token string" > ' .' < / span > < span class = "token punctuation" > )< / span > < span class = "token punctuation" > [< / span > < span class = "token operator" > -< / span > < span class = "token number" > 1< / span > < span class = "token punctuation" > ]< / span > < span class = "token punctuation" > }< / span > < / span > < span class = "token string" > )" < / span > < / span > < span class = "token punctuation" > ,< / span > metadata< span class = "token punctuation" > .< / span > < span class = "token builtin" > type< / span > < span class = "token punctuation" > )< / span >
< span class = "token keyword" > elif< / span > module< span class = "token punctuation" > .< / span > __dict__< span class = "token punctuation" > .< / span > get< span class = "token punctuation" > (< / span > < span class = "token string" > ' __plugin_meta__' < / span > < span class = "token punctuation" > ,< / span > < span class = "token boolean" > None< / span > < span class = "token punctuation" > )< / span > < span class = "token punctuation" > :< / span >
metadata< span class = "token punctuation" > :< / span > < span class = "token string" > ' PluginMetadata' < / span > < span class = "token operator" > =< / span > module< span class = "token punctuation" > .< / span > __dict__< span class = "token punctuation" > [< / span > < span class = "token string" > ' __plugin_meta__' < / span > < span class = "token punctuation" > ]< / span >
display_name < span class = "token operator" > =< / span > format_display_name< span class = "token punctuation" > (< / span > < span class = "token string-interpolation" > < span class = "token string" > f" < / span > < span class = "token interpolation" > < span class = "token punctuation" > {< / span > metadata< span class = "token punctuation" > .< / span > name< span class = "token punctuation" > }< / span > < / span > < span class = "token string" > (< / span > < span class = "token interpolation" > < span class = "token punctuation" > {< / span > module< span class = "token punctuation" > .< / span > __name__< span class = "token punctuation" > .< / span > split< span class = "token punctuation" > (< / span > < span class = "token string" > ' .' < / span > < span class = "token punctuation" > )< / span > < span class = "token punctuation" > [< / span > < span class = "token operator" > -< / span > < span class = "token number" > 1< / span > < span class = "token punctuation" > ]< / span > < span class = "token punctuation" > }< / span > < / span > < span class = "token string" > )" < / span > < / span > < span class = "token punctuation" > ,< / span > metadata< span class = "token punctuation" > .< / span > < span class = "token builtin" > type< / span > < span class = "token punctuation" > )< / span >
< span class = "token keyword" > else< / span > < span class = "token punctuation" > :< / span >
logger< span class = "token punctuation" > .< / span > opt< span class = "token punctuation" > (< / span > colors< span class = "token operator" > =< / span > < span class = "token boolean" > True< / span > < span class = "token punctuation" > )< / span > < span class = "token punctuation" > .< / span > warning< span class = "token punctuation" > (< / span > < span class = "token string-interpolation" > < span class = "token string" > f' The metadata of Liteyuki plugin " < / span > < span class = "token interpolation" > < span class = "token punctuation" > {< / span > module< span class = "token punctuation" > .< / span > __name__< span class = "token punctuation" > }< / span > < / span > < span class = "token string" > " is not specified, use empty.' < / span > < / span > < span class = "token punctuation" > )< / span >
metadata < span class = "token operator" > =< / span > PluginMetadata< span class = "token punctuation" > (< / span > name< span class = "token operator" > =< / span > module< span class = "token punctuation" > .< / span > __name__< span class = "token punctuation" > )< / span >
display_name < span class = "token operator" > =< / span > module< span class = "token punctuation" > .< / span > __name__< span class = "token punctuation" > .< / span > split< span class = "token punctuation" > (< / span > < span class = "token string" > ' .' < / span > < span class = "token punctuation" > )< / span > < span class = "token punctuation" > [< / span > < span class = "token operator" > -< / span > < span class = "token number" > 1< / span > < span class = "token punctuation" > ]< / span >
_plugins< span class = "token punctuation" > [< / span > module< span class = "token punctuation" > .< / span > __name__< span class = "token punctuation" > ]< / span > < span class = "token punctuation" > .< / span > metadata < span class = "token operator" > =< / span > metadata
logger< span class = "token punctuation" > .< / span > opt< span class = "token punctuation" > (< / span > colors< span class = "token operator" > =< / span > < span class = "token boolean" > True< / span > < span class = "token punctuation" > )< / span > < span class = "token punctuation" > .< / span > success< span class = "token punctuation" > (< / span > < span class = "token string-interpolation" > < span class = "token string" > f' Succeeded to load liteyuki plugin " < / span > < span class = "token interpolation" > < span class = "token punctuation" > {< / span > display_name< span class = "token punctuation" > }< / span > < / span > < span class = "token string" > " ' < / span > < / span > < span class = "token punctuation" > )< / span >
< span class = "token keyword" > return< / span > _plugins< span class = "token punctuation" > [< / span > module< span class = "token punctuation" > .< / span > __name__< span class = "token punctuation" > ]< / span >
< span class = "token keyword" > except< / span > Exception < span class = "token keyword" > as< / span > e< span class = "token punctuation" > :< / span >
logger< span class = "token punctuation" > .< / span > opt< span class = "token punctuation" > (< / span > colors< span class = "token operator" > =< / span > < span class = "token boolean" > True< / span > < span class = "token punctuation" > )< / span > < span class = "token punctuation" > .< / span > success< span class = "token punctuation" > (< / span > < span class = "token string-interpolation" > < span class = "token string" > f' Failed to load liteyuki plugin " < r> < / span > < span class = "token interpolation" > < span class = "token punctuation" > {< / span > module_path< span class = "token punctuation" > }< / span > < / span > < span class = "token string" > < /r> " ' < / span > < / span > < span class = "token punctuation" > )< / span >
traceback< span class = "token punctuation" > .< / span > print_exc< span class = "token punctuation" > (< / span > < span class = "token punctuation" > )< / span >
< span class = "token keyword" > return< / span > < span class = "token boolean" > None< / span >
< / code > < / pre > < div class = "line-numbers" aria-hidden = "true" > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < / div > < / div > < / details > < h3 id = "func-load-plugins-ignore-warning-bool-true-set-plugin" tabindex = "-1" > < a class = "header-anchor" href = "#func-load-plugins-ignore-warning-bool-true-set-plugin" > < span > < em > func< / em > < code > load_plugins(*, ignore_warning: bool = True) -> set[Plugin]< / code > < / span > < / a > < / h3 > < p > < strong > 说明< / strong > : 导入文件夹下多个插件< / p > < p > < strong > 参数< / strong > :< / p > < blockquote > < ul > < li > plugin_dir: 文件夹路径< / li > < li > ignore_warning: 是否忽略警告,通常是目录不存在或目录为空< / li > < / ul > < / blockquote > < details > < summary > < b > 源代码< / b > < / summary > < div class = "language-python line-numbers-mode" data-ext = "py" data-title = "py" > < pre class = "language-python" > < code > < span class = "token keyword" > def< / span > < span class = "token function" > load_plugins< / span > < span class = "token punctuation" > (< / span > < span class = "token operator" > *< / span > plugin_dir< span class = "token punctuation" > :< / span > < span class = "token builtin" > str< / span > < span class = "token punctuation" > ,< / span > ignore_warning< span class = "token punctuation" > :< / span > < span class = "token builtin" > bool< / span > < span class = "token operator" > =< / span > < span class = "token boolean" > True< / span > < span class = "token punctuation" > )< / span > < span class = "token operator" > -< / span > < span class = "token operator" > > < / span > < span class = "token builtin" > set< / span > < span class = "token punctuation" > [< / span > Plugin< span class = "token punctuation" > ]< / span > < span class = "token punctuation" > :< / span >
< span class = "token triple-quoted-string string" > " " " 导入文件夹下多个插件
参数:
plugin_dir: 文件夹路径
ignore_warning: 是否忽略警告,通常是目录不存在或目录为空
" " " < / span >
plugins < span class = "token operator" > =< / span > < span class = "token builtin" > set< / span > < span class = "token punctuation" > (< / span > < span class = "token punctuation" > )< / span >
< span class = "token keyword" > for< / span > dir_path < span class = "token keyword" > in< / span > plugin_dir< span class = "token punctuation" > :< / span >
< span class = "token keyword" > if< / span > < span class = "token keyword" > not< / span > os< span class = "token punctuation" > .< / span > path< span class = "token punctuation" > .< / span > exists< span class = "token punctuation" > (< / span > dir_path< span class = "token punctuation" > )< / span > < span class = "token punctuation" > :< / span >
< span class = "token keyword" > if< / span > < span class = "token keyword" > not< / span > ignore_warning< span class = "token punctuation" > :< / span >
logger< span class = "token punctuation" > .< / span > warning< span class = "token punctuation" > (< / span > < span class = "token string-interpolation" > < span class = "token string" > f" Plugins dir ' < / span > < span class = "token interpolation" > < span class = "token punctuation" > {< / span > dir_path< span class = "token punctuation" > }< / span > < / span > < span class = "token string" > ' does not exist." < / span > < / span > < span class = "token punctuation" > )< / span >
< span class = "token keyword" > continue< / span >
< span class = "token keyword" > if< / span > < span class = "token keyword" > not< / span > os< span class = "token punctuation" > .< / span > listdir< span class = "token punctuation" > (< / span > dir_path< span class = "token punctuation" > )< / span > < span class = "token punctuation" > :< / span >
< span class = "token keyword" > if< / span > < span class = "token keyword" > not< / span > ignore_warning< span class = "token punctuation" > :< / span >
logger< span class = "token punctuation" > .< / span > warning< span class = "token punctuation" > (< / span > < span class = "token string-interpolation" > < span class = "token string" > f" Plugins dir ' < / span > < span class = "token interpolation" > < span class = "token punctuation" > {< / span > dir_path< span class = "token punctuation" > }< / span > < / span > < span class = "token string" > ' is empty." < / span > < / span > < span class = "token punctuation" > )< / span >
< span class = "token keyword" > continue< / span >
< span class = "token keyword" > if< / span > < span class = "token keyword" > not< / span > os< span class = "token punctuation" > .< / span > path< span class = "token punctuation" > .< / span > isdir< span class = "token punctuation" > (< / span > dir_path< span class = "token punctuation" > )< / span > < span class = "token punctuation" > :< / span >
< span class = "token keyword" > if< / span > < span class = "token keyword" > not< / span > ignore_warning< span class = "token punctuation" > :< / span >
logger< span class = "token punctuation" > .< / span > warning< span class = "token punctuation" > (< / span > < span class = "token string-interpolation" > < span class = "token string" > f" Plugins dir ' < / span > < span class = "token interpolation" > < span class = "token punctuation" > {< / span > dir_path< span class = "token punctuation" > }< / span > < / span > < span class = "token string" > ' is not a directory." < / span > < / span > < span class = "token punctuation" > )< / span >
< span class = "token keyword" > continue< / span >
< span class = "token keyword" > for< / span > f < span class = "token keyword" > in< / span > os< span class = "token punctuation" > .< / span > listdir< span class = "token punctuation" > (< / span > dir_path< span class = "token punctuation" > )< / span > < span class = "token punctuation" > :< / span >
path < span class = "token operator" > =< / span > Path< span class = "token punctuation" > (< / span > os< span class = "token punctuation" > .< / span > path< span class = "token punctuation" > .< / span > join< span class = "token punctuation" > (< / span > dir_path< span class = "token punctuation" > ,< / span > f< span class = "token punctuation" > )< / span > < span class = "token punctuation" > )< / span >
module_name < span class = "token operator" > =< / span > < span class = "token boolean" > None< / span >
< span class = "token keyword" > if< / span > os< span class = "token punctuation" > .< / span > path< span class = "token punctuation" > .< / span > isfile< span class = "token punctuation" > (< / span > path< span class = "token punctuation" > )< / span > < span class = "token keyword" > and< / span > f< span class = "token punctuation" > .< / span > endswith< span class = "token punctuation" > (< / span > < span class = "token string" > ' .py' < / span > < span class = "token punctuation" > )< / span > < span class = "token keyword" > and< / span > < span class = "token punctuation" > (< / span > f < span class = "token operator" > !=< / span > < span class = "token string" > ' __init__.py' < / span > < span class = "token punctuation" > )< / span > < span class = "token punctuation" > :< / span >
module_name < span class = "token operator" > =< / span > < span class = "token string-interpolation" > < span class = "token string" > f' < / span > < span class = "token interpolation" > < span class = "token punctuation" > {< / span > path_to_module_name< span class = "token punctuation" > (< / span > Path< span class = "token punctuation" > (< / span > dir_path< span class = "token punctuation" > )< / span > < span class = "token punctuation" > )< / span > < span class = "token punctuation" > }< / span > < / span > < span class = "token string" > .< / span > < span class = "token interpolation" > < span class = "token punctuation" > {< / span > f< span class = "token punctuation" > [< / span > < span class = "token punctuation" > :< / span > < span class = "token format-spec" > -3]< / span > < span class = "token punctuation" > }< / span > < / span > < span class = "token string" > ' < / span > < / span >
< span class = "token keyword" > elif< / span > os< span class = "token punctuation" > .< / span > path< span class = "token punctuation" > .< / span > isdir< span class = "token punctuation" > (< / span > path< span class = "token punctuation" > )< / span > < span class = "token keyword" > and< / span > os< span class = "token punctuation" > .< / span > path< span class = "token punctuation" > .< / span > exists< span class = "token punctuation" > (< / span > os< span class = "token punctuation" > .< / span > path< span class = "token punctuation" > .< / span > join< span class = "token punctuation" > (< / span > path< span class = "token punctuation" > ,< / span > < span class = "token string" > ' __init__.py' < / span > < span class = "token punctuation" > )< / span > < span class = "token punctuation" > )< / span > < span class = "token punctuation" > :< / span >
module_name < span class = "token operator" > =< / span > path_to_module_name< span class = "token punctuation" > (< / span > path< span class = "token punctuation" > )< / span >
< span class = "token keyword" > if< / span > module_name< span class = "token punctuation" > :< / span >
load_plugin< span class = "token punctuation" > (< / span > module_name< span class = "token punctuation" > )< / span >
< span class = "token keyword" > if< / span > _plugins< span class = "token punctuation" > .< / span > get< span class = "token punctuation" > (< / span > module_name< span class = "token punctuation" > )< / span > < span class = "token punctuation" > :< / span >
plugins< span class = "token punctuation" > .< / span > add< span class = "token punctuation" > (< / span > _plugins< span class = "token punctuation" > [< / span > module_name< span class = "token punctuation" > ]< / span > < span class = "token punctuation" > )< / span >
< span class = "token keyword" > return< / span > plugins
< / code > < / pre > < div class = "line-numbers" aria-hidden = "true" > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < / div > < / div > < / details > < h3 id = "func-format-display-name-str" tabindex = "-1" > < a class = "header-anchor" href = "#func-format-display-name-str" > < span > < em > func< / em > < code > format_display_name() -> str< / code > < / span > < / a > < / h3 > < p > < strong > 说明< / strong > : 设置插件名称颜色,根据不同类型插件设置颜色< / p > < p > < strong > 参数< / strong > :< / p > < blockquote > < ul > < li > display_name: 插件名称< / li > < li > plugin_type: 插件类型< / li > < / ul > < / blockquote > < p > < strong > 返回< / strong > : str: 设置后的插件名称 <!-- --> < / p > < details > < summary > < b > 源代码< / b > < / summary > < div class = "language-python line-numbers-mode" data-ext = "py" data-title = "py" > < pre class = "language-python" > < code > < span class = "token keyword" > def< / span > < span class = "token function" > format_display_name< / span > < span class = "token punctuation" > (< / span > display_name< span class = "token punctuation" > :< / span > < span class = "token builtin" > str< / span > < span class = "token punctuation" > ,< / span > plugin_type< span class = "token punctuation" > :< / span > PluginType< span class = "token punctuation" > )< / span > < span class = "token operator" > -< / span > < span class = "token operator" > > < / span > < span class = "token builtin" > str< / span > < span class = "token punctuation" > :< / span >
< span class = "token triple-quoted-string string" > " " "
设置插件名称颜色,根据不同类型插件设置颜色
Args:
display_name: 插件名称
plugin_type: 插件类型
Returns:
str: 设置后的插件名称 < y> name< /y>
" " " < / span >
color < span class = "token operator" > =< / span > < span class = "token string" > ' y' < / span >
< span class = "token keyword" > match< / span > plugin_type< span class = "token punctuation" > :< / span >
< span class = "token keyword" > case< / span > PluginType< span class = "token punctuation" > .< / span > APPLICATION< span class = "token punctuation" > :< / span >
color < span class = "token operator" > =< / span > < span class = "token string" > ' m' < / span >
< span class = "token keyword" > case< / span > PluginType< span class = "token punctuation" > .< / span > TEST< span class = "token punctuation" > :< / span >
color < span class = "token operator" > =< / span > < span class = "token string" > ' g' < / span >
< span class = "token keyword" > case< / span > PluginType< span class = "token punctuation" > .< / span > MODULE< span class = "token punctuation" > :< / span >
color < span class = "token operator" > =< / span > < span class = "token string" > ' e' < / span >
< span class = "token keyword" > case< / span > PluginType< span class = "token punctuation" > .< / span > SERVICE< span class = "token punctuation" > :< / span >
color < span class = "token operator" > =< / span > < span class = "token string" > ' c' < / span >
< span class = "token keyword" > return< / span > < span class = "token string-interpolation" > < span class = "token string" > f' < < / span > < span class = "token interpolation" > < span class = "token punctuation" > {< / span > color< span class = "token punctuation" > }< / span > < / span > < span class = "token string" > > < / span > < span class = "token interpolation" > < span class = "token punctuation" > {< / span > display_name< span class = "token punctuation" > }< / span > < / span > < span class = "token string" > [< / span > < span class = "token interpolation" > < span class = "token punctuation" > {< / span > plugin_type< span class = "token punctuation" > .< / span > name< span class = "token punctuation" > }< / span > < / span > < span class = "token string" > ]< /< / span > < span class = "token interpolation" > < span class = "token punctuation" > {< / span > color< span class = "token punctuation" > }< / span > < / span > < span class = "token string" > > ' < / span > < / span >
2024-08-29 15:51:25 +08:00
< / code > < / pre > < div class = "line-numbers" aria-hidden = "true" > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < div class = "line-number" > < / div > < / div > < / div > < / details > < / div > <!-- [ --> <!-- --> <!-- ] --> < footer class = "page-meta" > < div class = "meta-item edit-link" > < a href = "https://github.com/LiteyukiStudio/LiteyukiBot/edit/main/docs/dev/api/plugin/load.md" rel = "noopener noreferrer" target = "_blank" aria-label = "在 GitHub 上编辑" class = "nav-link label" > <!-- [ --> < svg xmlns = "http://www.w3.org/2000/svg" class = "icon edit-icon" viewBox = "0 0 1024 1024" fill = "currentColor" aria-label = "edit icon" > < path d = "M430.818 653.65a60.46 60.46 0 0 1-50.96-93.281l71.69-114.012 7.773-10.365L816.038 80.138A60.46 60.46 0 0 1 859.225 62a60.46 60.46 0 0 1 43.186 18.138l43.186 43.186a60.46 60.46 0 0 1 0 86.373L588.879 565.55l-8.637 8.637-117.466 68.234a60.46 60.46 0 0 1-31.958 11.229z" > < / path > < path d = "M728.802 962H252.891A190.883 190.883 0 0 1 62.008 771.98V296.934a190.883 190.883 0 0 1 190.883-192.61h267.754a60.46 60.46 0 0 1 0 120.92H252.891a69.962 69.962 0 0 0-69.098 69.099V771.98a69.962 69.962 0 0 0 69.098 69.098h475.911A69.962 69.962 0 0 0 797.9 771.98V503.363a60.46 60.46 0 1 1 120.922 0V771.98A190.883 190.883 0 0 1 728.802 962z" > < / path > < / svg > <!-- ] --> 在 GitHub 上编辑< span > < svg class = "external-link-icon" xmlns = "http://www.w3.org/2000/svg" aria-hidden = "true" focusable = "false" x = "0px" y = "0px" viewBox = "0 0 100 100" width = "15" height = "15" > < path fill = "currentColor" d = "M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z" > < / path > < polygon fill = "currentColor" points = "45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9" > < / polygon > < / svg > < span class = "external-link-icon-sr-only" > open in new window< / span > < / span > <!-- --> < / a > < / div > < div class = "meta-item git-info" > < div class = "update-time" > < span class = "label" > 上次编辑于: < / span > <!-- --> < / div > < div class = "contributors" > < span class = "label" > 贡献者: < / span > <!-- [ --> <!-- [ --> < span class = "contributor" title = "email: snowykami@outlook.com" > snowy< / span > <!-- ] --> <!-- ] --> < / div > < / div > < / footer > < nav class = "vp-page-nav" > < a class = "route-link nav-link active prev" href = "/dev/api/plugin/" aria-label = "liteyuki.plugin" > < div class = "hint" > < span class = "arrow start" > < / span > 上一页< / div > < div class = "link" > <!-- --> liteyuki.plugin< / div > < / a > < a class = "route-link nav-link next" href = "/dev/api/plugin/manager.html" aria-label = "liteyuki.plugin.manager" > < div class = "hint" > 下一页< span class = "arrow end" > < / span > < / div > < div class = "link" > liteyuki.plugin.manager<!-- --> < / div > < / a > < / nav > < div id = "vp-comment" class = "giscus-wrapper input-top" style = "display:block;" > < svg xmlns = "http://www.w3.org/2000/svg" width = "32" height = "32" preserveAspectRatio = "xMidYMid" viewBox = "0 0 100 100" > < circle cx = "28" cy = "75" r = "11" fill = "currentColor" > < animate attributeName = "fill-opacity" begin = "0s" dur = "1s" keyTimes = "0;0.2;1" repeatCount = "indefinite" values = "0;1;1" > < / animate > < / circle > < path fill = "none" stroke = "#88baf0" stroke-width = "10" d = "M28 47a28 28 0 0 1 28 28" > < animate attributeName = "stroke-opacity" begin = "0.1s" dur = "1s" keyTimes = "0;0.2;1" repeatCount = "indefinite" values = "0;1;1" > < / animate > < / path > < path fill = "none" stroke = "#88baf0" stroke-width = "10" d = "M28 25a50 50 0 0 1 50 50" > < animate attributeName = "stroke-opacity" begin = "0.2s" dur = "1s" keyTimes = "0;0.2;1" repeatCount = "indefinite" values = "0;1;1" > < / animate > < / path > < / svg > < / div > <!-- [ --> <!-- --> <!-- ] --> <!-- ] --> < / main > <!-- ] --> < footer class = "vp-footer-wrapper" > < div class = "vp-foote
< script type = "module" src = "/assets/app-BiKNfxRB.js" defer > < / script >
2024-08-29 14:21:20 +08:00
< / body >
< / html >