{"id":473,"date":"2020-12-25T13:55:25","date_gmt":"2020-12-25T05:55:25","guid":{"rendered":"http:\/\/blog.refusea.com\/?p=473"},"modified":"2020-12-25T13:55:25","modified_gmt":"2020-12-25T05:55:25","slug":"python-%e6%89%be%e4%b8%8d%e5%88%b0%e8%87%aa%e5%ae%9a%e4%b9%89%e5%8c%85","status":"publish","type":"post","link":"https:\/\/refusea.com\/?p=473","title":{"rendered":"python \u627e\u4e0d\u5230\u81ea\u5b9a\u4e49\u5305"},"content":{"rendered":"<h2>\u8be1\u5f02\u7684 ModuleNotFoundError<\/h2>\n<p>\u6211\u7684 python \u5de5\u7a0b\u76ee\u5f55\u7ed3\u6784\u5982\u4e0b<\/p>\n<pre><code class=\"language-bash\">tree \/data\/python\/\n\/data\/python\/\n\u2514\u2500\u2500 px500\n    \u251c\u2500\u2500 config\n    \u2502   \u251c\u2500\u2500 __init__.py\n    \u2502   \u2514\u2500\u2500 config.py\n    \u251c\u2500\u2500 jd\n    \u2502   \u251c\u2500\u2500 __init__.py\n    \u2502   \u2514\u2500\u2500 jd_api.py\n    \u251c\u2500\u2500 lib\n    \u2502   \u251c\u2500\u2500 __init__.py\n    \u2502   \u2514\u2500\u2500 log.py\n    \u2514\u2500\u2500 webapp.py\n<\/code><\/pre>\n<p>\u6709 3 \u4e2a\u81ea\u5b9a\u4e49\u5305\u5206\u522b\u662f <code>config<\/code>\uff0c<code>jd<\/code>\uff0c<code>lib<\/code>\uff0c\u5728 <code>lib<\/code> \u5305\u91cc\u7684 py \u6587\u4ef6\u53ef\u4ee5 import <code>config<\/code> \u5305\u91cc\u7684\u6a21\u5757\uff0c\u4f46\u662f\u5728 <code>jd<\/code> \u5305\u91cc\u7684 py \u6587\u4ef6\u5374\u4e0d\u80fd import <code>lib<\/code> \u5305\u91cc\u7684\u6a21\u5757<\/p>\n<p>\u9519\u8bef\u63d0\u793a\u5982\u4e0b<\/p>\n<pre><code class=\"language-bash\">python3 \/data\/python\/px500\/jd\/jd_api.py\nTraceback (most recent call last):\n  File &quot;\/data\/python\/px500\/jd\/jd_api.py&quot;, line 8, in &lt;module&gt;\n    from lib.log import root_log\nModuleNotFoundError: No module named &#039;lib&#039;<\/code><\/pre>\n<h2>\u89e3\u51b3\u529e\u6cd5<\/h2>\n<p>\u5c06\u5de5\u7a0b\u76ee\u5f55\u6dfb\u52a0\u5230\u7cfb\u7edf\u8def\u5f84\u91cc\uff0c\u8fd9\u6837 python \u5c31\u80fd\u627e\u5230\u5305\u4e86<\/p>\n<p>\u6ce8\u610f\uff1a\u9700\u8981\u5728 <code>jd_api.py<\/code> \u7684 <code>from lib.log import root_log<\/code> \u4ee3\u7801\u524d\u6267\u884c<\/p>\n<pre><code class=\"language-python\"># -*- coding: utf-8 -*-\n\nimport sys\nsys.path.append(&#039;\/data\/python\/px500&#039;)\n\nfrom lib.log import root_log\nimport time\n\n......<\/code><\/pre>\n<p>\u641e\u5b9a\uff0c\u6536\u5de5<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u8be1\u5f02\u7684 ModuleNotFoundError \u6211\u7684 python \u5de5\u7a0b\u76ee\u5f55\u7ed3\u6784\u5982\u4e0b tree \/data\/p [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[38],"tags":[],"class_list":["post-473","post","type-post","status-publish","format-standard","hentry","category-python"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v22.3 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>python \u627e\u4e0d\u5230\u81ea\u5b9a\u4e49\u5305 - \u62d2\u6d77\u7a7a\u95f4<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/refusea.com\/?p=473\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"refusea.com\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"1 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/refusea.com\/?p=473#article\",\"isPartOf\":{\"@id\":\"https:\/\/refusea.com\/?p=473\"},\"author\":{\"name\":\"refusea.com\",\"@id\":\"https:\/\/refusea.com\/#\/schema\/person\/b5393cc8b15717000d19424552aae0df\"},\"headline\":\"python \u627e\u4e0d\u5230\u81ea\u5b9a\u4e49\u5305\",\"datePublished\":\"2020-12-25T05:55:25+00:00\",\"dateModified\":\"2020-12-25T05:55:25+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/refusea.com\/?p=473\"},\"wordCount\":8,\"commentCount\":0,\"publisher\":{\"@id\":\"https:\/\/refusea.com\/#\/schema\/person\/b5393cc8b15717000d19424552aae0df\"},\"articleSection\":[\"python\"],\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\/\/refusea.com\/?p=473#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/refusea.com\/?p=473\",\"url\":\"https:\/\/refusea.com\/?p=473\",\"name\":\"python \u627e\u4e0d\u5230\u81ea\u5b9a\u4e49\u5305 - \u62d2\u6d77\u7a7a\u95f4\",\"isPartOf\":{\"@id\":\"https:\/\/refusea.com\/#website\"},\"datePublished\":\"2020-12-25T05:55:25+00:00\",\"dateModified\":\"2020-12-25T05:55:25+00:00\",\"breadcrumb\":{\"@id\":\"https:\/\/refusea.com\/?p=473#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/refusea.com\/?p=473\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/refusea.com\/?p=473#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/refusea.com\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"python \u627e\u4e0d\u5230\u81ea\u5b9a\u4e49\u5305\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/refusea.com\/#website\",\"url\":\"https:\/\/refusea.com\/\",\"name\":\"\u62d2\u6d77\u7a7a\u95f4\",\"description\":\"\u62d2\u6d77\u7684\u4e2a\u4eba\u535a\u5ba2\",\"publisher\":{\"@id\":\"https:\/\/refusea.com\/#\/schema\/person\/b5393cc8b15717000d19424552aae0df\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/refusea.com\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"zh-Hans\"},{\"@type\":[\"Person\",\"Organization\"],\"@id\":\"https:\/\/refusea.com\/#\/schema\/person\/b5393cc8b15717000d19424552aae0df\",\"name\":\"refusea.com\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/refusea.com\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/7f7489b4afdbd952db64e7a6704d1258?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/7f7489b4afdbd952db64e7a6704d1258?s=96&d=mm&r=g\",\"caption\":\"refusea.com\"},\"logo\":{\"@id\":\"https:\/\/refusea.com\/#\/schema\/person\/image\/\"},\"sameAs\":[\"https:\/\/refusea.com\"]}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"python \u627e\u4e0d\u5230\u81ea\u5b9a\u4e49\u5305 - \u62d2\u6d77\u7a7a\u95f4","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/refusea.com\/?p=473","twitter_misc":{"\u4f5c\u8005":"refusea.com","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"1 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/refusea.com\/?p=473#article","isPartOf":{"@id":"https:\/\/refusea.com\/?p=473"},"author":{"name":"refusea.com","@id":"https:\/\/refusea.com\/#\/schema\/person\/b5393cc8b15717000d19424552aae0df"},"headline":"python \u627e\u4e0d\u5230\u81ea\u5b9a\u4e49\u5305","datePublished":"2020-12-25T05:55:25+00:00","dateModified":"2020-12-25T05:55:25+00:00","mainEntityOfPage":{"@id":"https:\/\/refusea.com\/?p=473"},"wordCount":8,"commentCount":0,"publisher":{"@id":"https:\/\/refusea.com\/#\/schema\/person\/b5393cc8b15717000d19424552aae0df"},"articleSection":["python"],"inLanguage":"zh-Hans","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/refusea.com\/?p=473#respond"]}]},{"@type":"WebPage","@id":"https:\/\/refusea.com\/?p=473","url":"https:\/\/refusea.com\/?p=473","name":"python \u627e\u4e0d\u5230\u81ea\u5b9a\u4e49\u5305 - \u62d2\u6d77\u7a7a\u95f4","isPartOf":{"@id":"https:\/\/refusea.com\/#website"},"datePublished":"2020-12-25T05:55:25+00:00","dateModified":"2020-12-25T05:55:25+00:00","breadcrumb":{"@id":"https:\/\/refusea.com\/?p=473#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/refusea.com\/?p=473"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/refusea.com\/?p=473#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/refusea.com\/"},{"@type":"ListItem","position":2,"name":"python \u627e\u4e0d\u5230\u81ea\u5b9a\u4e49\u5305"}]},{"@type":"WebSite","@id":"https:\/\/refusea.com\/#website","url":"https:\/\/refusea.com\/","name":"\u62d2\u6d77\u7a7a\u95f4","description":"\u62d2\u6d77\u7684\u4e2a\u4eba\u535a\u5ba2","publisher":{"@id":"https:\/\/refusea.com\/#\/schema\/person\/b5393cc8b15717000d19424552aae0df"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/refusea.com\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"zh-Hans"},{"@type":["Person","Organization"],"@id":"https:\/\/refusea.com\/#\/schema\/person\/b5393cc8b15717000d19424552aae0df","name":"refusea.com","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/refusea.com\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/7f7489b4afdbd952db64e7a6704d1258?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/7f7489b4afdbd952db64e7a6704d1258?s=96&d=mm&r=g","caption":"refusea.com"},"logo":{"@id":"https:\/\/refusea.com\/#\/schema\/person\/image\/"},"sameAs":["https:\/\/refusea.com"]}]}},"_links":{"self":[{"href":"https:\/\/refusea.com\/index.php?rest_route=\/wp\/v2\/posts\/473"}],"collection":[{"href":"https:\/\/refusea.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/refusea.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/refusea.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/refusea.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=473"}],"version-history":[{"count":3,"href":"https:\/\/refusea.com\/index.php?rest_route=\/wp\/v2\/posts\/473\/revisions"}],"predecessor-version":[{"id":476,"href":"https:\/\/refusea.com\/index.php?rest_route=\/wp\/v2\/posts\/473\/revisions\/476"}],"wp:attachment":[{"href":"https:\/\/refusea.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=473"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/refusea.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=473"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/refusea.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=473"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}