{"id":16475,"date":"2024-01-25T16:16:11","date_gmt":"2024-01-25T12:46:11","guid":{"rendered":"https:\/\/rasanegar.com\/blog\/%d8%a7%d8%b5%d9%88%d9%84-%d8%ab%d8%a8%d8%aa-%d9%be%d8%a7%db%8c%d8%aa%d9%88%d9%86\/"},"modified":"2024-01-25T16:16:11","modified_gmt":"2024-01-25T12:46:11","slug":"%d8%a7%d8%b5%d9%88%d9%84-%d8%ab%d8%a8%d8%aa-%d9%be%d8%a7%db%8c%d8%aa%d9%88%d9%86","status":"publish","type":"post","link":"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b5%d9%88%d9%84-%d8%ab%d8%a8%d8%aa-%d9%be%d8%a7%db%8c%d8%aa%d9%88%d9%86\/","title":{"rendered":"\u0627\u0635\u0648\u0644 \u062b\u0628\u062a \u067e\u0627\u06cc\u062a\u0648\u0646"},"content":{"rendered":"<div id=\"ez-toc-container\" class=\"ez-toc-v2_0_85 counter-hierarchy ez-toc-counter ez-toc-custom ez-toc-container-direction\">\n<div class=\"ez-toc-title-container\"><p class=\"ez-toc-title\" style=\"cursor:inherit\">\u0633\u0631\u0641\u0635\u0644\u0647\u0627\u06cc \u0645\u0637\u0644\u0628<\/p>\n<\/div><nav><ul class='ez-toc-list ez-toc-list-level-1 ' ><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-1\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b5%d9%88%d9%84-%d8%ab%d8%a8%d8%aa-%d9%be%d8%a7%db%8c%d8%aa%d9%88%d9%86\/#%d9%85%d8%b9%d8%b1%d9%81%db%8c\" >\u0645\u0639\u0631\u0641\u06cc<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-2\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b5%d9%88%d9%84-%d8%ab%d8%a8%d8%aa-%d9%be%d8%a7%db%8c%d8%aa%d9%88%d9%86\/#%d8%b1%d8%a7_logging_%d9%85%d8%af%d9%88%d9%84\" >\u0631\u0627 logging \u0645\u062f\u0648\u0644<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-3\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b5%d9%88%d9%84-%d8%ab%d8%a8%d8%aa-%d9%be%d8%a7%db%8c%d8%aa%d9%88%d9%86\/#%d8%a7%d9%86%d9%88%d8%a7%d8%b9_%d9%88%d8%b1%d9%88%d8%af_%d8%a8%d9%87_%d8%b3%db%8c%d8%b3%d8%aa%d9%85_%d8%b3%d8%b7%d9%88%d8%ad_%da%af%d8%b2%d8%a7%d8%b1%d8%b4\" >\u0627\u0646\u0648\u0627\u0639 \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 (\u0633\u0637\u0648\u062d \u06af\u0632\u0627\u0631\u0634)<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-4\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b5%d9%88%d9%84-%d8%ab%d8%a8%d8%aa-%d9%be%d8%a7%db%8c%d8%aa%d9%88%d9%86\/#%d8%a7%d8%b4%db%8c%d8%a7%d8%a1_logger\" >\u0627\u0634\u06cc\u0627\u0621 Logger<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b5%d9%88%d9%84-%d8%ab%d8%a8%d8%aa-%d9%be%d8%a7%db%8c%d8%aa%d9%88%d9%86\/#%d9%88%d8%b1%d9%88%d8%af_%d8%a8%d9%87_%d9%81%d8%a7%db%8c%d9%84_%d8%af%d8%b1_%d9%85%d9%82%d8%a7%d8%a8%d9%84_%d8%ae%d8%b1%d9%88%d8%ac%db%8c_%d8%a7%d8%b3%d8%aa%d8%a7%d9%86%d8%af%d8%a7%d8%b1%d8%af\" >\u0648\u0631\u0648\u062f \u0628\u0647 \u0641\u0627\u06cc\u0644 \u062f\u0631 \u0645\u0642\u0627\u0628\u0644 \u062e\u0631\u0648\u062c\u06cc \u0627\u0633\u062a\u0627\u0646\u062f\u0627\u0631\u062f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-6\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b5%d9%88%d9%84-%d8%ab%d8%a8%d8%aa-%d9%be%d8%a7%db%8c%d8%aa%d9%88%d9%86\/#%d8%aa%d8%a7%d8%b1%db%8c%d8%ae%d8%b2%d9%85%d8%a7%d9%86_%d8%af%d8%b1_%d9%be%db%8c%d8%a7%d9%85%e2%80%8c%d9%87%d8%a7%db%8c_%d9%88%d8%b1%d9%88%d8%af\" >\u062a\u0627\u0631\u06cc\u062e\/\u0632\u0645\u0627\u0646 \u062f\u0631 \u067e\u06cc\u0627\u0645\u200c\u0647\u0627\u06cc \u0648\u0631\u0648\u062f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-7\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b5%d9%88%d9%84-%d8%ab%d8%a8%d8%aa-%d9%be%d8%a7%db%8c%d8%aa%d9%88%d9%86\/#%d9%85%d8%aa%d8%ba%db%8c%d8%b1%d9%87%d8%a7%db%8c_%d9%88%d8%b1%d9%88%d8%af_%d8%a8%d9%87_%d8%b3%db%8c%d8%b3%d8%aa%d9%85\" >\u0645\u062a\u063a\u06cc\u0631\u0647\u0627\u06cc \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-8\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b5%d9%88%d9%84-%d8%ab%d8%a8%d8%aa-%d9%be%d8%a7%db%8c%d8%aa%d9%88%d9%86\/#%d8%ab%d8%a8%d8%aa_%d8%b1%d8%af%db%8c%d8%a7%d8%a8%db%8c_%d9%be%d8%b4%d8%aa%d9%87\" >\u062b\u0628\u062a \u0631\u062f\u06cc\u0627\u0628\u06cc \u067e\u0634\u062a\u0647<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-9\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b5%d9%88%d9%84-%d8%ab%d8%a8%d8%aa-%d9%be%d8%a7%db%8c%d8%aa%d9%88%d9%86\/#%d9%86%d8%aa%db%8c%d8%ac%d9%87\" >\u0646\u062a\u06cc\u062c\u0647<\/a><\/li><\/ul><\/nav><\/div>\n<span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 6<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span><p> <br \/>\n<\/p>\n<div><noscript><\/noscript><\/p>\n<h2 id=\"introduction\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%b9%d8%b1%d9%81%db%8c\"><\/span>\u0645\u0639\u0631\u0641\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u0628\u0647 \u0634\u0645\u0627 \u06a9\u0645\u06a9 \u0645\u06cc\u200c\u06a9\u0646\u062f \u062a\u0627 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc\u06cc \u0631\u0627 \u06a9\u0647 \u062f\u0631 \u0637\u0648\u0644 \u0627\u062c\u0631\u0627\u06cc \u06a9\u062f\u062a\u0627\u0646 \u0627\u062a\u0641\u0627\u0642 \u0645\u06cc\u200c\u0627\u0641\u062a\u062f \u0631\u0627 \u067e\u06cc\u06af\u06cc\u0631\u06cc \u06a9\u0646\u06cc\u062f\u060c \u06a9\u0647 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u062f \u062f\u0631 \u0622\u06cc\u0646\u062f\u0647 \u0628\u0631\u0627\u06cc \u0627\u0647\u062f\u0627\u0641 \u0627\u0634\u06a9\u0627\u0644\u200c\u0632\u062f\u0627\u06cc\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0634\u0648\u062f.  \u062a\u0635\u0648\u06cc\u0631 \u0628\u0647\u062a\u0631\u06cc \u0627\u0632 \u062c\u0631\u06cc\u0627\u0646 \u0628\u0631\u0646\u0627\u0645\u0647 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f \u0648 \u0628\u0647 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u06a9\u0645\u06a9 \u0645\u06cc \u06a9\u0646\u062f \u062a\u0627 \u0645\u0646\u0628\u0639 \u062e\u0637\u0627\u0647\u0627\u06cc\u06cc \u0631\u0627 \u06a9\u0647 \u062f\u0631 \u062d\u06cc\u0646 \u0627\u062c\u0631\u0627\u06cc \u06a9\u062f \u0634\u0645\u0627 \u0631\u062e \u0645\u06cc \u062f\u0647\u062f \u0631\u062f\u06cc\u0627\u0628\u06cc \u06a9\u0646\u0646\u062f \u0648 \u062f\u0631 \u0646\u062a\u06cc\u062c\u0647 \u0642\u0627\u0628\u0644\u06cc\u062a \u0646\u06af\u0647\u062f\u0627\u0631\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u0627 \u0627\u0641\u0632\u0627\u06cc\u0634 \u0645\u06cc \u062f\u0647\u062f.<\/p>\n<p>\u062f\u0631 \u067e\u0627\u06cc\u062a\u0648\u0646\u060c \u0628\u06cc\u0634\u062a\u0631 \u0648\u06cc\u0698\u06af\u06cc\u200c\u0647\u0627\u06cc \u0627\u0635\u0644\u06cc \u062b\u0628\u062a\u200c\u0646\u0627\u0645 \u062a\u0648\u0633\u0637 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0627\u0633\u062a\u0627\u0646\u062f\u0627\u0631\u062f \u067e\u0627\u06cc\u062a\u0648\u0646 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc\u200c\u0634\u0648\u062f.  \u0627\u0632 \u0627\u06cc\u0646 \u0631\u0648\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc \u0648 \u0628\u062f\u0648\u0646 \u0647\u06cc\u0686 \u06af\u0648\u0646\u0647 \u062a\u0646\u0638\u06cc\u0645\u0627\u062a \u0627\u0636\u0627\u0641\u06cc\u060c \u0644\u0627\u06af \u0631\u0627 \u0628\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f.  \u0645\u0627\u0698\u0648\u0644 \u0627\u0633\u062a\u0627\u0646\u062f\u0627\u0631\u062f \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u0647 \u0631\u0627 \u0642\u0627\u062f\u0631 \u0645\u06cc \u0633\u0627\u0632\u062f \u062a\u0627 \u067e\u06cc\u0627\u0645 \u0647\u0627\u06cc \u0648\u0636\u0639\u06cc\u062a \u0631\u0627 \u062f\u0631 \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u06cc\u0627 \u0647\u0631 \u062c\u0631\u06cc\u0627\u0646 \u062e\u0631\u0648\u062c\u06cc \u062f\u06cc\u06af\u0631\u06cc \u0628\u0646\u0648\u06cc\u0633\u062f.<\/p>\n<h2 id=\"theloggingmodule\"><span class=\"ez-toc-section\" id=\"%d8%b1%d8%a7_logging_%d9%85%d8%af%d9%88%d9%84\"><\/span>\u0631\u0627 <code>logging<\/code> \u0645\u062f\u0648\u0644<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0631\u0627 <code>logging<\/code> \u0645\u0627\u0698\u0648\u0644 \u0628\u0647\u200c\u0637\u0648\u0631 \u067e\u06cc\u0634\u200c\u0641\u0631\u0636 \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc \u062f\u0631 \u0645\u062d\u06cc\u0637\u200c\u0647\u0627\u06cc \u067e\u0627\u06cc\u062a\u0648\u0646 \u062f\u0631 \u062f\u0633\u062a\u0631\u0633 \u0627\u0633\u062a \u0648 \u06cc\u06a9 \u0644\u0627\u06af\u0631 \u067e\u06cc\u0634\u200c\u0641\u0631\u0636 \u0628\u0647 \u0646\u0627\u0645 \u00abroot&#8221;. \u062a\u0648\u0627\u0628\u0639 \u0648 \u06a9\u0644\u0627\u0633 \u0647\u0627\u06cc\u06cc \u0631\u0627 \u06a9\u0647 \u0639\u0645\u0644\u06a9\u0631\u062f \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u0631\u0627 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0645\u06cc \u06a9\u0646\u0646\u062f\u060c \u062a\u0639\u0631\u06cc\u0641 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>API \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u0627\u0631\u0627\u0626\u0647 \u0634\u062f\u0647 \u062a\u0648\u0633\u0637 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0627\u0633\u062a\u0627\u0646\u062f\u0627\u0631\u062f \u0628\u0647 \u0634\u0645\u0627 \u0627\u0645\u06a9\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f \u067e\u06cc\u0627\u0645 \u0647\u0627\u06cc \u062e\u0648\u062f \u0631\u0627 \u062f\u0631 \u06af\u0632\u0627\u0631\u0634 \u0628\u0631\u0646\u0627\u0645\u0647 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0628\u0627 \u067e\u06cc\u0627\u0645 \u0647\u0627\u06cc \u0645\u0627\u0698\u0648\u0644 \u0647\u0627\u06cc \u0634\u062e\u0635 \u062b\u0627\u0644\u062b \u06cc\u06a9\u067e\u0627\u0631\u0686\u0647 \u0634\u0648\u06cc\u062f.  \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06a9\u0627\u0646\u06cc\u0632\u0645\u06cc \u0628\u0631\u0627\u06cc \u062d\u0627\u0634\u06cc\u0647 \u0646\u0648\u06cc\u0633\u06cc \u067e\u06cc\u0627\u0645 \u0647\u0627\u06cc \u06af\u0632\u0627\u0631\u0634 \u0628\u0627 \u0645\u0646\u0628\u0639\u060c \u0645\u0647\u0631 \u0632\u0645\u0627\u0646\u06cc\u060c \u0634\u062f\u062a \u0648 \u0633\u0627\u06cc\u0631 \u0627\u0628\u0631\u062f\u0627\u062f\u0647 \u0647\u0627 \u0641\u0631\u0627\u0647\u0645 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0628\u0647 \u062a\u062c\u0632\u06cc\u0647 \u0648 \u062a\u062d\u0644\u06cc\u0644 \u06af\u0632\u0627\u0631\u0634 \u06a9\u0645\u06a9 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<h2 id=\"loggingtypesloglevels\"><span class=\"ez-toc-section\" id=\"%d8%a7%d9%86%d9%88%d8%a7%d8%b9_%d9%88%d8%b1%d9%88%d8%af_%d8%a8%d9%87_%d8%b3%db%8c%d8%b3%d8%aa%d9%85_%d8%b3%d8%b7%d9%88%d8%ad_%da%af%d8%b2%d8%a7%d8%b1%d8%b4\"><\/span>\u0627\u0646\u0648\u0627\u0639 \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 (\u0633\u0637\u0648\u062d \u06af\u0632\u0627\u0631\u0634)<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0647\u0631 \u067e\u06cc\u0627\u0645 \u06af\u0632\u0627\u0631\u0634 \u0628\u0627 \u06cc\u06a9 \u0633\u0637\u062d \u0634\u062f\u062a \u0647\u0645\u0631\u0627\u0647 \u0627\u0633\u062a\u060c \u06a9\u0647 \u06cc\u06a9 \u0639\u062f\u062f \u0635\u062d\u06cc\u062d \u0627\u0633\u062a \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0646\u0634\u0627\u0646 \u062f\u0627\u062f\u0646 \u0628\u062d\u0631\u0627\u0646\u06cc \u0628\u0648\u062f\u0646 \u0631\u0648\u06cc\u062f\u0627\u062f(\u0647\u0627\u06cc) \u062b\u0628\u062a \u0634\u062f\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.  \u0645\u0627\u0698\u0648\u0644 \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u062f\u0627\u0631\u0627\u06cc \u06cc\u06a9 \u062a\u0627\u0628\u0639 \u06a9\u0645\u06a9\u06cc \u0628\u0631\u0627\u06cc \u0647\u0631 \u0633\u0637\u062d \u06af\u0632\u0627\u0631\u0634 \u0627\u0633\u062a &#8211; \u0627\u06cc\u0646\u0647\u0627 \u0628\u0627 \u062a\u0648\u062c\u0647 \u0628\u0647 \u0633\u0637\u062d \u06af\u0632\u0627\u0631\u0634 \u0646\u0627\u0645\u06af\u0630\u0627\u0631\u06cc \u0645\u06cc \u0634\u0648\u0646\u062f.  \u062f\u0631 \u0632\u06cc\u0631\u060c \u0644\u06cc\u0633\u062a\u06cc \u0627\u0632 \u0633\u0637\u0648\u062d \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u0628\u0647 \u0647\u0645\u0631\u0627\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062a\u0648\u0635\u06cc\u0647 \u0634\u062f\u0647 \u0627\u0632 \u0622\u0646\u0647\u0627 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f.<\/p>\n<ul>\n<li>\n<p>\u0627\u0634\u06a9\u0627\u0644 \u0632\u062f\u0627\u06cc\u06cc (<code>logger.debug<\/code>): \u062e\u0631\u0648\u062c\u06cc \u0628\u0633\u06cc\u0627\u0631 \u062f\u0642\u06cc\u0642 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f.  \u0628\u0631\u0627\u06cc \u062a\u0634\u062e\u06cc\u0635 \u0645\u0634\u06a9\u0644\u0627\u062a \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<\/li>\n<li>\n<p>\u0627\u0637\u0644\u0627\u0639\u0627\u062a (<code>logger.info<\/code>): \u0627\u0637\u0644\u0627\u0639\u0627\u062a\u06cc \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f \u0631\u0648\u06cc \u0627\u062c\u0631\u0627\u06cc \u0645\u0648\u0641\u0642  \u062a\u0623\u06cc\u06cc\u062f \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0622\u06cc\u0627 \u06a9\u0627\u0631\u0647\u0627 \u0645\u0637\u0627\u0628\u0642 \u0627\u0646\u062a\u0638\u0627\u0631 \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u0646\u062f \u06cc\u0627 \u062e\u06cc\u0631.<\/p>\n<\/li>\n<li>\n<p>\u0647\u0634\u062f\u0627\u0631 (<code>logger.warn<\/code> \u06cc\u0627 <code>logger.warning<\/code>): \u062f\u0631 \u0645\u0648\u0631\u062f \u0645\u0634\u06a9\u0644\u06cc \u06a9\u0647 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u062f\u0631 \u0622\u06cc\u0646\u062f\u0647 \u0631\u062e \u062f\u0647\u062f \u06cc\u0627 \u062e\u0637\u0627\u06cc \u0642\u0627\u0628\u0644 \u0628\u0627\u0632\u06cc\u0627\u0628\u06cc\u060c \u0647\u0634\u062f\u0627\u0631\u06cc \u0635\u0627\u062f\u0631 \u06a9\u0646\u06cc\u062f.<\/p>\n<\/li>\n<li>\n<p>\u062e\u0637\u0627 (<code>logger.error<\/code>): \u0646\u0634\u0627\u0646 \u062f\u0647\u0646\u062f\u0647 \u0645\u0634\u06a9\u0644\u06cc \u062f\u0631 \u0646\u0631\u0645 \u0627\u0641\u0632\u0627\u0631 \u0627\u0633\u062a \u0632\u06cc\u0631\u0627 \u0637\u0628\u0642 \u0627\u0646\u062a\u0638\u0627\u0631 \u0627\u062c\u0631\u0627 \u0646\u0645\u06cc \u0634\u0648\u062f.<\/p>\n<\/li>\n<li>\n<p>\u0628\u062d\u0631\u0627\u0646\u06cc (<code>logger.critical<\/code>): \u0646\u0634\u0627\u0646 \u062f\u0647\u0646\u062f\u0647 \u06cc\u06a9 \u062e\u0637\u0627\u06cc \u062c\u062f\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0627\u062c\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u0627 \u0645\u062a\u0648\u0642\u0641 \u06a9\u0646\u062f.<\/p>\n<\/li>\n<\/ul>\n<p>\u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636\u060c root Logger \u0628\u0631\u0627\u06cc \u06af\u0632\u0627\u0631\u0634 \u0647\u0645\u0647 \u067e\u06cc\u0627\u0645 \u0647\u0627 \u062f\u0631 \u0633\u0637\u062d \u0647\u0634\u062f\u0627\u0631 \u06cc\u0627 \u0628\u0627\u0644\u0627\u062a\u0631 \u0627\u0632 \u0622\u0646 \u062a\u0646\u0638\u06cc\u0645 \u0634\u062f\u0647 \u0627\u0633\u062a &#8211; \u0647\u0631 \u067e\u06cc\u0627\u0645\u06cc \u06a9\u0647 \u0632\u06cc\u0631 \u0627\u06cc\u0646 \u0633\u0637\u062d \u0628\u0627\u0634\u062f \u0641\u06cc\u0644\u062a\u0631 \u0645\u06cc \u0634\u0648\u062f.  \u0628\u0627 \u0627\u06cc\u0646 \u062d\u0627\u0644\u060c \u0627\u06cc\u0646 \u0627\u0645\u06a9\u0627\u0646 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u0645\u0627\u0698\u0648\u0644 \u0631\u0627 \u0628\u0647 \u0635\u0631\u0627\u062d\u062a \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u06a9\u0646\u06cc\u062f \u062a\u0627 \u062f\u0631 \u0641\u06cc\u0644\u062a\u0631\u06cc\u0646\u06af \u06a9\u0645 \u0648 \u0628\u06cc\u0634 \u0627\u0646\u062a\u062e\u0627\u0628\u06cc \u0628\u0627\u0634\u062f.<\/p>\n<p>\u0628\u0631\u0627\u06cc \u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0646 \u0644\u0627\u06af \u0628\u0647 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u067e\u0627\u06cc\u062a\u0648\u0646\u060c \u0641\u0642\u0637 import \u0645\u0627\u0698\u0648\u0644 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <code>import logging<\/code>\u060c \u0648 \u067e\u0633 \u0627\u0632 \u0645\u0648\u0641\u0642\u06cc\u062a \u0622\u0645\u06cc\u0632 import \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u067e\u06cc\u0627\u0645 \u0647\u0627 \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <code>logging.*<\/code> \u0631\u0648\u0634 \u0647\u0627\u06cc\u06cc \u0645\u0627\u0646\u0646\u062f <code>logging.debug()<\/code>.<\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u06cc\u06a9 \u0645\u062b\u0627\u0644 \u0633\u0627\u062f\u0647 \u0627\u0632 \u0645\u0627\u0698\u0648\u0644 \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u0631\u0627 \u0645\u0634\u0627\u0647\u062f\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> logging\nlogging.warning(<span class=\"hljs-string\">\"Caution: This is the root logger!\"<\/span>)\n<\/code><\/pre>\n<p><strong>\u062e\u0631\u0648\u062c\u06cc:<\/strong><\/p>\n<pre><code class=\"hljs\">WARNING:root:Caution: This is the root logger!\n<\/code><\/pre>\n<h2 id=\"loggerobjects\"><span class=\"ez-toc-section\" id=\"%d8%a7%d8%b4%db%8c%d8%a7%d8%a1_logger\"><\/span>\u0627\u0634\u06cc\u0627\u0621 Logger<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0631\u0627 <code>logging<\/code> \u0645\u0627\u0698\u0648\u0644 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0627\u06cc\u0646 \u0627\u0645\u06a9\u0627\u0646 \u0631\u0627 \u0645\u06cc \u062f\u0647\u062f \u06a9\u0647 \u0686\u0646\u062f\u06cc\u0646 \u0634\u06cc\u0621 \u0644\u0627\u06af\u0631 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u062f.  \u0627\u0646\u0648\u0627\u0639 \u0645\u062e\u062a\u0644\u0641\u06cc \u0627\u0632 \u0627\u0634\u06cc\u0627\u0621 \u0644\u0627\u06af\u0631 \u0631\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646 \u0628\u0631\u0627\u06cc \u0628\u0647 \u062f\u0633\u062a \u0622\u0648\u0631\u062f\u0646 \u06a9\u0646\u062a\u0631\u0644 \u062f\u0642\u06cc\u0642 \u0628\u0631 \u0631\u0648\u0634 \u062b\u0628\u062a \u067e\u06cc\u0627\u0645 \u0647\u0627\u06cc \u0628\u062e\u0634 \u0647\u0627\u06cc \u0645\u062e\u062a\u0644\u0641 \u0628\u0631\u0646\u0627\u0645\u0647 \u067e\u0627\u06cc\u062a\u0648\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f &#8211; \u0628\u0631\u0627\u06cc \u0645\u062b\u0627\u0644\u060c \u0628\u0631\u0646\u0627\u0645\u0647 \u0627\u0635\u0644\u06cc \u067e\u0627\u06cc\u062a\u0648\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0627\u0632 <code>root<\/code> logger \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0647\u0627\u06cc \u0634\u062e\u0635 \u062b\u0627\u0644\u062b \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0634\u062f\u0647 \u0627\u0632 \u062f\u0627\u062e\u0644 \u0627\u06cc\u0646 \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0627\u0632 \u0627\u0634\u06cc\u0627\u0621 \u062b\u0628\u062a \u06a9\u0646\u0646\u062f\u0647 \u062e\u0648\u062f \u0628\u0627 \u062a\u0646\u0638\u06cc\u0645\u0627\u062a \u062e\u0627\u0635 \u062e\u0648\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u0646\u062f.<\/p>\n<p>\u0647\u0646\u06af\u0627\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u067e\u06cc\u0634 \u0641\u0631\u0636 <code>root<\/code> \u062a\u0648\u0627\u0628\u0639 \u0644\u0627\u06af\u0631\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u062a\u0648\u0627\u0628\u0639 \u0631\u0627 \u0645\u0633\u062a\u0642\u06cc\u0645\u0627\u064b \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u06a9\u0646\u06cc\u0645\u060c \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c <code>logging.debug()<\/code>.  \u0627\u06cc\u0646 \u0627\u0645\u06a9\u0627\u0646 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u0628\u0627 \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0634\u06cc \u0627\u0632 \u0644\u0627\u06af\u0631 \u062e\u0648\u062f \u0631\u0627 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u06a9\u0646\u06cc\u062f <code>Logger<\/code> class\u060c \u0648 \u0627\u06cc\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0645\u0641\u06cc\u062f \u0628\u0627\u0634\u062f \u0627\u06af\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u062f\u0627\u0631\u0627\u06cc \u0686\u0646\u062f\u06cc\u0646 \u0645\u0627\u0698\u0648\u0644 \u0628\u0627\u0634\u062f.<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0646\u06af\u0627\u0647\u06cc \u0628\u0647 \u0628\u0631\u062e\u06cc \u0627\u0632 \u06a9\u0644\u0627\u0633 \u0647\u0627 \u0648 \u062a\u0648\u0627\u0628\u0639 \u0645\u0648\u062c\u0648\u062f \u062f\u0631 \u0622\u0646 \u0628\u06cc\u0627\u0646\u062f\u0627\u0632\u06cc\u0645 <code>logging<\/code> \u0645\u062f\u0648\u0644.  \u06a9\u0644\u0627\u0633 \u0647\u0627\u06cc \u0627\u0635\u0644\u06cc \u0648 \u0639\u0645\u0644\u06a9\u0631\u062f \u0622\u0646\u0647\u0627 \u0628\u0647 \u0634\u0631\u062d \u0632\u06cc\u0631 \u0627\u0633\u062a:<\/p>\n<ul>\n<li>\n<p>Loggers &#8211; \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u06a9\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f \u0631\u0627 \u0646\u0634\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f.  \u0627\u0634\u06cc\u0627\u0621 \u0627\u06cc\u0646 \u06a9\u0644\u0627\u0633 \u0645\u0633\u062a\u0642\u06cc\u0645\u0627\u064b \u0628\u0631\u0627\u06cc \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u062a\u0648\u0627\u0628\u0639 \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u0646\u062f.<\/p>\n<\/li>\n<li>\n<p>Handlers &#8211; \u067e\u06cc\u0627\u0645 \u0647\u0627\u06cc \u06af\u0632\u0627\u0631\u0634 \u0631\u0627 \u0628\u0647 \u0645\u06a9\u0627\u0646 \u0645\u0646\u0627\u0633\u0628 \u062f\u0631 \u0646\u0631\u0645 \u0627\u0641\u0632\u0627\u0631 \u0645\u0627\u0646\u0646\u062f \u062e\u0631\u0648\u062c\u06cc \u0627\u0633\u062a\u0627\u0646\u062f\u0627\u0631\u062f \u0645\u06cc \u0641\u0631\u0633\u062a\u062f console\u060c \u06cc\u06a9 \u0641\u0627\u06cc\u0644\u060c \u0627\u0632 \u0637\u0631\u06cc\u0642 HTTP \u06cc\u0627 \u062d\u062a\u06cc \u0627\u06cc\u0645\u06cc\u0644 (\u0627\u0632 \u0637\u0631\u06cc\u0642 SMTP).<\/p>\n<\/li>\n<li>\n<p>\u0641\u06cc\u0644\u062a\u0631\u0647\u0627 &#8211; \u06a9\u0646\u062a\u0631\u0644 \u062f\u0642\u06cc\u0642\u06cc \u0628\u0631 \u0627\u0646\u062a\u062e\u0627\u0628 \u0631\u06a9\u0648\u0631\u062f\u0647\u0627\u06cc \u06af\u0632\u0627\u0631\u0634 \u0628\u0631\u0627\u06cc \u0646\u0645\u0627\u06cc\u0634 \u0645\u06cc \u062f\u0647\u062f.<\/p>\n<\/li>\n<li>\n<p>Formatters &#8211; \u0637\u0631\u062d \u0646\u0647\u0627\u06cc\u06cc \u0631\u06a9\u0648\u0631\u062f\u0647\u0627\u06cc \u06af\u0632\u0627\u0631\u0634 \u0631\u0627 \u0645\u0634\u062e\u0635 \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc\u06cc \u0631\u0627 \u06a9\u0647 \u062e\u0631\u0648\u062c\u06cc \u0628\u0627\u06cc\u062f \u0634\u0627\u0645\u0644 \u0634\u0648\u062f \u0631\u0627 \u0645\u0634\u062e\u0635 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<\/li>\n<\/ul>\n<p>\u0627\u0632 \u0627\u06cc\u0646 \u0645\u06cc\u0627\u0646\u060c \u0627\u0634\u06cc\u0627\u0621 \u0627\u0632 <code>Logger<\/code> \u06a9\u0644\u0627\u0633 \u0628\u06cc\u0634\u062a\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0644\u0627\u06af\u0631 \u062c\u062f\u06cc\u062f\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0632 <code>logging.getLogger()<\/code> \u0631\u0648\u0634.  \u062f\u0631 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0632\u06cc\u0631\u060c \u062e\u0637\u0627\u0647\u0627 \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 log \u062b\u0628\u062a \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645 <code>root<\/code> \u0644\u0627\u06af\u0631 \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0644\u0627\u06af\u0631 \u0633\u0641\u0627\u0631\u0634\u06cc \u0645\u0627 <code>my_logger<\/code>.<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> logging\n\nmy_logger = logging.getLogger(<span class=\"hljs-string\">\"My Logger\"<\/span>)\nlogging.error(<span class=\"hljs-string\">\"Error: Root Log\"<\/span>)\nmy_logger.error(<span class=\"hljs-string\">\"Error: My Logger log\"<\/span>)\n<\/code><\/pre>\n<p><strong>\u062e\u0631\u0648\u062c\u06cc:<\/strong><\/p>\n<pre><code class=\"hljs\">ERROR:root:Error: Root Log\nERROR:My Logger:Error: My Logger log\n<\/code><\/pre>\n<p>\u0647\u0631 \u067e\u06cc\u0627\u0645 \u06af\u0632\u0627\u0631\u0634 \u0646\u0647 \u062a\u0646\u0647\u0627 \u0645\u0646\u0628\u0639 \u0631\u0627 \u0646\u0634\u0627\u0646 \u0645\u06cc\u200c\u062f\u0647\u062f &#8211; \u0634\u06cc\u0621 \u062b\u0628\u062a\u200c\u06a9\u0646\u0646\u062f\u0647\u200c\u0627\u06cc \u06a9\u0647 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0622\u0646 \u062b\u0628\u062a \u0634\u062f\u0647 \u0627\u0633\u062a &#8211; \u0628\u0644\u06a9\u0647 \u06cc\u06a9 \u067e\u06cc\u0627\u0645 \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u0622\u0646 \u0631\u0627 \u0646\u0634\u0627\u0646 \u0645\u06cc\u200c\u062f\u0647\u062f. \u0631\u0648\u06cc \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0622\u0646 \u0634\u06cc \u0644\u0627\u06af\u0631.<\/p>\n<p>\u062f\u0631 \u0628\u062e\u0634\u200c\u0647\u0627\u06cc \u0628\u0639\u062f\u06cc\u060c \u06af\u0632\u06cc\u0646\u0647\u200c\u0647\u0627\u06cc \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0645\u062e\u062a\u0644\u0641 \u0622\u0628\u062c\u06a9\u062a\u200c\u0647\u0627\u06cc \u0644\u0627\u06af\u0631 \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f.<\/p>\n<h2 id=\"loggingtoafilevsthestandardoutput\"><span class=\"ez-toc-section\" id=\"%d9%88%d8%b1%d9%88%d8%af_%d8%a8%d9%87_%d9%81%d8%a7%db%8c%d9%84_%d8%af%d8%b1_%d9%85%d9%82%d8%a7%d8%a8%d9%84_%d8%ae%d8%b1%d9%88%d8%ac%db%8c_%d8%a7%d8%b3%d8%aa%d8%a7%d9%86%d8%af%d8%a7%d8%b1%d8%af\"><\/span>\u0648\u0631\u0648\u062f \u0628\u0647 \u0641\u0627\u06cc\u0644 \u062f\u0631 \u0645\u0642\u0627\u0628\u0644 \u062e\u0631\u0648\u062c\u06cc \u0627\u0633\u062a\u0627\u0646\u062f\u0627\u0631\u062f<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u0647\u200c\u0637\u0648\u0631 \u067e\u06cc\u0634\u200c\u0641\u0631\u0636\u060c \u0627\u0634\u06cc\u0627\u0621 \u0644\u0627\u06af\u0631\u060c \u06af\u0632\u0627\u0631\u0634\u200c\u0647\u0627 \u0631\u0627 \u0628\u0647 \u062e\u0631\u0648\u062c\u06cc \u0627\u0633\u062a\u0627\u0646\u062f\u0627\u0631\u062f \u062e\u0631\u0648\u062c\u06cc \u0645\u06cc\u200c\u062f\u0647\u0646\u062f.  \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f <code>basicConfig()<\/code> \u0631\u0648\u0634\u06cc \u0628\u0631\u0627\u06cc \u062a\u063a\u06cc\u06cc\u0631 \u0627\u06cc\u0646 \u067e\u0627\u0631\u0627\u0645\u062a\u0631 \u0648 \u0633\u0627\u06cc\u0631 \u067e\u0627\u0631\u0627\u0645\u062a\u0631\u0647\u0627.  \u062f\u0631 \u0632\u06cc\u0631 \u0644\u06cc\u0633\u062a\u06cc \u0627\u0632 \u067e\u0627\u0631\u0627\u0645\u062a\u0631\u0647\u0627 \u0628\u0631\u0627\u06cc <code>basicConfig<\/code> \u0631\u0648\u0634:<\/p>\n<ul>\n<li>\u0633\u0637\u062d: \u06cc\u06a9 \u0633\u0637\u062d \u0634\u062f\u062a \u0628\u0631\u0627\u06cc \u0644\u0627\u06af\u0631 \u062a\u0639\u06cc\u06cc\u0646 \u06a9\u0646\u06cc\u062f.  \u0647\u06cc\u0686 \u067e\u06cc\u0627\u0645\u06cc \u06a9\u0645\u062a\u0631 \u0627\u0632 \u0627\u06cc\u0646 \u0633\u0637\u062d \u0634\u062f\u062a \u062b\u0628\u062a \u0646\u062e\u0648\u0627\u0647\u062f \u0634\u062f.<\/li>\n<li>filename: \u0646\u0627\u0645 \u0641\u0627\u06cc\u0644\u06cc \u06a9\u0647 \u0644\u0627\u06af \u0647\u0627 \u062f\u0631 \u0622\u0646 \u0646\u0648\u0634\u062a\u0647 \u0645\u06cc \u0634\u0648\u0646\u062f.<\/li>\n<li>filemode: \u062d\u0627\u0644\u062a\u06cc \u06a9\u0647 \u062f\u0631 \u0622\u0646 \u0641\u0627\u06cc\u0644 \u0645\u0634\u062e\u0635 \u0634\u062f\u0647\u060c \u062f\u0631 \u0635\u0648\u0631\u062a \u0648\u062c\u0648\u062f\u060c \u0628\u0627\u06cc\u062f \u0628\u0627\u0632 \u0634\u0648\u062f.<\/li>\n<li>format: \u0641\u0631\u0645\u062a \u067e\u06cc\u0627\u0645 \u06af\u0632\u0627\u0631\u0634 \u0631\u0627 \u0645\u0634\u062e\u0635 \u0645\u06cc \u06a9\u0646\u062f.  \u0627\u06cc\u0646 \u06cc\u06a9 \u0631\u0634\u062a\u0647 \u0628\u0627 <code>LogRecord<\/code> \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc.<\/li>\n<\/ul>\n<p><code>LogRecord<\/code>  \u0634\u06cc \u062d\u0627\u0648\u06cc \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc\u06cc \u0627\u0633\u062a \u06a9\u0647 \u062b\u0628\u062a \u0634\u062f\u0647 \u0627\u0646\u062f\u060c \u0645\u0627\u0646\u0646\u062f \u0634\u0645\u0627\u0631\u0647 \u062e\u0637\u060c \u0632\u0645\u0627\u0646\u060c \u0646\u0627\u0645 \u0644\u0627\u06af\u0631 \u0648 \u063a\u06cc\u0631\u0647. \u0628\u062d\u062b \u062f\u0631 \u0645\u0648\u0631\u062f \u0634\u06cc LogRecord \u062e\u0627\u0631\u062c \u0627\u0632 \u0645\u062d\u062f\u0648\u062f\u0647 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647 \u0627\u0633\u062a \u0627\u0645\u0627 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0628\u06cc\u0634\u062a\u0631\u06cc \u062f\u0631 \u062f\u0633\u062a\u0631\u0633 \u0627\u0633\u062a. <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/docs.python.org\/3\/library\/logging.html#logrecord-attributes\">\u0627\u06cc\u0646\u062c\u0627<\/a>.<\/p>\n<p>\u062f\u0631 \u0632\u06cc\u0631 \u062e\u0644\u0627\u0635\u0647 \u0627\u06cc \u0627\u0632 \u0645\u0631\u0627\u062d\u0644\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0627\u06cc\u062f \u0628\u0631\u0627\u06cc \u062b\u0628\u062a \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc \u06af\u0632\u0627\u0631\u0634 \u062f\u0631 \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u062f\u0646\u0628\u0627\u0644 \u0634\u0648\u062f:<\/p>\n<ol>\n<li>\u0645\u0627\u0698\u0648\u0644 \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u0631\u0627 \u0648\u0627\u0631\u062f \u06a9\u0646\u06cc\u062f.<\/li>\n<li>\u0644\u0627\u06af\u0631 \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u06a9\u0646\u06cc\u062f <code>basicConfig<\/code> \u0631\u0648\u0634<\/li>\n<li>\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0634\u06cc \u0644\u0627\u06af\u0631.<\/li>\n<li>\u062a\u0646\u0638\u06cc\u0645 \u0645\u0642\u062f\u0627\u0631 \u0622\u0633\u062a\u0627\u0646\u0647 \u0644\u0627\u06af\u0631.<\/li>\n<li>\u0627\u0632 \u0631\u0648\u0634 \u0647\u0627\u06cc \u062b\u0628\u062a \u0646\u0627\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.<\/li>\n<\/ol>\n<p>\u0627\u06cc\u0646 \u0631\u0627 \u0628\u0627 \u06cc\u06a9 \u0645\u062b\u0627\u0644 \u0628\u0647\u062a\u0631 \u0645\u06cc \u062a\u0648\u0627\u0646 \u0641\u0647\u0645\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\">\n\n<span class=\"hljs-keyword\">import<\/span> logging\n\n\nlogger = logging.getLogger()\n\n\nlogging.basicConfig(filename=<span class=\"hljs-string\">\"test.log\"<\/span>, <span class=\"hljs-built_in\">format<\/span>=<span class=\"hljs-string\">'%(filename)s: %(message)s'<\/span>, filemode=<span class=\"hljs-string\">'w'<\/span>)\n\n\nlogger.setLevel(logging.DEBUG)\n\n\nlogger.debug(<span class=\"hljs-string\">\"This is a debug message\"<\/span>)\nlogger.info(<span class=\"hljs-string\">\"For your info\"<\/span>)\nlogger.warning(<span class=\"hljs-string\">\"This is a warning message\"<\/span>)\nlogger.error(<span class=\"hljs-string\">\"This is an error message\"<\/span>)\nlogger.critical(<span class=\"hljs-string\">\"This is a critical message\"<\/span>)\n<\/code><\/pre>\n<p>\u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0628\u0627\u0644\u0627 \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f <code>test.log<\/code>.  \u0641\u0627\u06cc\u0644 \u062d\u0627\u0648\u06cc \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u0632\u06cc\u0631 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f:<\/p>\n<pre><code class=\"hljs\">test_logger.py: This is a debug message\ntest_logger.py: For your info\ntest_logger.py: This is a warning message\ntest_logger.py: This is an error message\ntest_logger.py: This is a critical message\n<\/code><\/pre>\n<h2 id=\"datetimeinlogmessages\"><span class=\"ez-toc-section\" id=\"%d8%aa%d8%a7%d8%b1%db%8c%d8%ae%d8%b2%d9%85%d8%a7%d9%86_%d8%af%d8%b1_%d9%be%db%8c%d8%a7%d9%85%e2%80%8c%d9%87%d8%a7%db%8c_%d9%88%d8%b1%d9%88%d8%af\"><\/span>\u062a\u0627\u0631\u06cc\u062e\/\u0632\u0645\u0627\u0646 \u062f\u0631 \u067e\u06cc\u0627\u0645\u200c\u0647\u0627\u06cc \u0648\u0631\u0648\u062f<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u0631\u0627\u06cc \u0646\u0645\u0627\u06cc\u0634 \u062a\u0627\u0631\u06cc\u062e \u0648 \u0632\u0645\u0627\u0646 \u0648\u0642\u0648\u0639 \u06cc\u06a9 \u0631\u0648\u06cc\u062f\u0627\u062f \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f <code>%(asctime)s<\/code> \u062f\u0631 \u0631\u0634\u062a\u0647 \u0641\u0631\u0645\u062a \u0634\u0645\u0627 \u062f\u0631 <code>basicConfig()<\/code> \u062a\u0627\u0628\u0639.  \u0645\u062b\u0644\u0627:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> logging\n\nlogging.basicConfig(<span class=\"hljs-built_in\">format<\/span>=<span class=\"hljs-string\">'%(asctime)s %(message)s'<\/span>)\nlogging.warning(<span class=\"hljs-string\">'is the time the Admin logged out.'<\/span>)\n<\/code><\/pre>\n<p><strong>\u062e\u0631\u0648\u062c\u06cc:<\/strong><\/p>\n<pre><code class=\"hljs\">2018-12-17 10:52:15,463 is the time the Admin logged out.\n<\/code><\/pre>\n<p>\u0627\u06af\u0631 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u062f \u0631\u0648\u0634 \u0646\u0645\u0627\u06cc\u0634 \u062a\u0627\u0631\u06cc\u062e\/\u0632\u0645\u0627\u0646 \u0631\u0627 \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0647\u06cc\u062f\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0622\u0646 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u06a9\u0646\u06cc\u062f <code>datefmt<\/code> \u067e\u0627\u0631\u0627\u0645\u062a\u0631 \u0627\u0632 <code>basicConfig<\/code> \u0631\u0648\u0634.<\/p>\n<h2 id=\"loggingvariables\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%aa%d8%ba%db%8c%d8%b1%d9%87%d8%a7%db%8c_%d9%88%d8%b1%d9%88%d8%af_%d8%a8%d9%87_%d8%b3%db%8c%d8%b3%d8%aa%d9%85\"><\/span>\u0645\u062a\u063a\u06cc\u0631\u0647\u0627\u06cc \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u062f\u0646\u06cc\u0627\u06cc \u0648\u0627\u0642\u0639\u06cc\u060c \u0645\u0627 \u0628\u0627\u06cc\u062f \u06af\u0632\u0627\u0631\u0634 \u0647\u0627\u06cc \u062e\u0631\u0648\u062c\u06cc \u0631\u0627 \u0628\u0627 \u062a\u0648\u062c\u0647 \u0628\u0647 \u062a\u063a\u06cc\u06cc\u0631\u0627\u062a \u062f\u06cc\u0646\u0627\u0645\u06cc\u06a9\u06cc \u06a9\u0647 \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627 \u0627\u062a\u0641\u0627\u0642 \u0645\u06cc \u0627\u0641\u062a\u062f\u060c \u062a\u0648\u0644\u06cc\u062f \u06a9\u0646\u06cc\u0645.  \u0647\u0645\u0627\u0646\u0637\u0648\u0631 \u06a9\u0647 \u062f\u0631 \u0645\u062b\u0627\u0644 \u0628\u0627\u0644\u0627 \u0645\u0634\u0627\u0647\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f\u060c \u0645\u062a\u062f\u0647\u0627\u06cc \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u06cc\u06a9 \u0631\u0634\u062a\u0647 \u0631\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0622\u0631\u06af\u0648\u0645\u0627\u0646 \u0645\u06cc \u06af\u06cc\u0631\u0646\u062f.  \u0639\u0644\u0627\u0648\u0647 \u0628\u0631 \u0627\u06cc\u0646\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0645\u062a\u063a\u06cc\u0631\u0647\u0627 \u0631\u0627 \u0648\u0627\u0631\u062f \u06a9\u0646\u06cc\u0645 \u0648 \u0631\u0634\u062a\u0647 \u0631\u0627 \u0628\u0627 \u0645\u062a\u063a\u06cc\u0631\u0647\u0627\u06cc\u06cc \u0642\u0627\u0644\u0628\u200c\u0628\u0646\u062f\u06cc \u06a9\u0646\u06cc\u0645 \u0648 \u0633\u067e\u0633 \u0622\u0646 \u0631\u0627 \u0628\u0647 \u0645\u062a\u062f log \u0627\u0631\u0633\u0627\u0644 \u06a9\u0646\u06cc\u0645.  \u062f\u0631 \u0632\u0645\u0627\u0646 \u0627\u062c\u0631\u0627\u060c \u0645\u0642\u062f\u0627\u0631 \u0645\u062a\u063a\u06cc\u0631\u0647\u0627 \u062f\u0631 \u067e\u06cc\u0627\u0645\u200c\u0647\u0627\u06cc \u06af\u0632\u0627\u0631\u0634 \u062e\u0631\u0648\u062c\u06cc \u062f\u0627\u062f\u0647 \u0645\u06cc\u200c\u0634\u0648\u062f.<\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u06cc\u06a9 \u0645\u062b\u0627\u0644 \u0627\u0632 \u0622\u0646 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0642\u0627\u0644\u0628 \u0628\u0646\u062f\u06cc \u0631\u0634\u062a\u0647 \u0622\u0648\u0631\u062f\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> logging\n\nstatus = <span class=\"hljs-string\">\"connection unavailable\"<\/span>\nlogging.error(<span class=\"hljs-string\">\"System reported: %s\"<\/span>, status)\n<\/code><\/pre>\n<p><strong>\u062e\u0631\u0648\u062c\u06cc:<\/strong><\/p>\n<pre><code class=\"hljs\">ERROR:root:System reported: connection unavailable\n<\/code><\/pre>\n<p>\u0634\u0631\u0648\u0639 \u0628\u0627 Python 3.6 f-Strings \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u062c\u0627\u06cc\u06af\u0632\u06cc\u0646\u06cc \u0628\u0631\u0627\u06cc \u062a\u0639\u06cc\u06cc\u0646 \u06a9\u0646\u0646\u062f\u0647 \u0647\u0627\u06cc \u0642\u0627\u0644\u0628 \u0631\u0634\u062a\u0647 \u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0634\u0648\u062f\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u062f\u0631 \u0635\u0648\u0631\u062a \u0648\u062c\u0648\u062f \u0686\u0646\u062f\u06cc\u0646 \u067e\u0627\u0631\u0627\u0645\u062a\u0631\u060c \u06a9\u062f \u0631\u0627 \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc \u0642\u0627\u0628\u0644 \u062e\u0648\u0627\u0646\u062f\u0646 \u0646\u06af\u0647 \u0645\u06cc \u062f\u0627\u0631\u062f.  \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0631\u0634\u062a\u0647 \u0647\u0627\u06cc f \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0647\u0631 \u0639\u0628\u0627\u0631\u062a \u067e\u0627\u06cc\u062a\u0648\u0646 \u0631\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0628\u062e\u0634\u06cc \u0627\u0632 \u067e\u06cc\u0627\u0645 \u0645\u0634\u062e\u0635 \u06a9\u0646\u06cc\u062f \u0648 \u062f\u0631 \u0637\u0648\u0644 \u0632\u0645\u0627\u0646 \u0627\u062c\u0631\u0627 \u0627\u0631\u0632\u06cc\u0627\u0628\u06cc \u0645\u06cc \u0634\u0648\u062f \u0648 \u0646\u062a\u06cc\u062c\u0647 \u062f\u0631 \u067e\u06cc\u0627\u0645 \u0647\u0627\u06cc \u06af\u0632\u0627\u0631\u0634 \u062c\u0627\u0633\u0627\u0632\u06cc \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u0645\u062b\u0627\u0644 \u0628\u0627\u0644\u0627 \u0631\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06cc\u06a9 \u0631\u0634\u062a\u0647 f \u062f\u0648\u0628\u0627\u0631\u0647 \u0646\u0648\u0634\u062a:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> logging\n\nstatus = <span class=\"hljs-string\">\"connection unavailable\"<\/span>\nlogging.error(<span class=\"hljs-string\">f'System reported: <span class=\"hljs-subst\">{status}<\/span>'<\/span>)\n<\/code><\/pre>\n<h2 id=\"loggingstacktraces\"><span class=\"ez-toc-section\" id=\"%d8%ab%d8%a8%d8%aa_%d8%b1%d8%af%db%8c%d8%a7%d8%a8%db%8c_%d9%be%d8%b4%d8%aa%d9%87\"><\/span>\u062b\u0628\u062a \u0631\u062f\u06cc\u0627\u0628\u06cc \u067e\u0634\u062a\u0647<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0636\u0628\u0637 \u0631\u062f\u06cc\u0627\u0628\u06cc \u067e\u0634\u062a\u0647 \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u0646\u06cc\u0632 \u062a\u0648\u0633\u0637 \u0645\u0627\u0698\u0648\u0644 \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u0645\u06cc \u0634\u0648\u062f.  \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0631\u062f\u0646 <code>exc_info<\/code> \u067e\u0627\u0631\u0627\u0645\u062a\u0631 \u0628\u0647 <code>True<\/code> \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u062a\u0648\u0627\u0628\u0639 \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u0628\u0647 \u0645\u0627 \u0627\u0645\u06a9\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f \u062a\u0627 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0627\u0633\u062a\u062b\u0646\u0627 \u0631\u0627 \u0636\u0628\u0637 \u06a9\u0646\u06cc\u0645.  \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0627\u06cc\u0646 \u062a\u0627\u0628\u0639\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0637\u0644\u0627\u0639\u0627\u062a\u06cc \u062f\u0631 \u0645\u0648\u0631\u062f \u0627\u0633\u062a\u062b\u0646\u0627\u06cc\u06cc \u06a9\u0647 \u062f\u0631 \u062d\u0627\u0644 \u062d\u0627\u0636\u0631 \u062f\u0631 \u062d\u0627\u0644 \u0631\u0633\u06cc\u062f\u06af\u06cc \u0627\u0633\u062a \u0628\u0647 \u062f\u0633\u062a \u0622\u0648\u0631\u06cc\u0645.  \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 \u0631\u0634\u062a\u0647 \u0641\u0639\u0644\u06cc \u0648 \u0642\u0627\u0628 \u067e\u0634\u062a\u0647 \u0641\u0639\u0644\u06cc \u0627\u0633\u062a.<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> logging\n\nmy_list = (<span class=\"hljs-number\">1<\/span>, <span class=\"hljs-number\">2<\/span>)\n<span class=\"hljs-keyword\">try<\/span>:\n    <span class=\"hljs-built_in\">print<\/span>(my_list(<span class=\"hljs-number\">3<\/span>)) \n<span class=\"hljs-keyword\">except<\/span> Exception <span class=\"hljs-keyword\">as<\/span> e:\n    logging.error(<span class=\"hljs-string\">\"Caught Exception!\"<\/span>, exc_info=<span class=\"hljs-literal\">True<\/span>)\n<\/code><\/pre>\n<p><strong>\u062e\u0631\u0648\u062c\u06cc:<\/strong><\/p>\n<pre><code class=\"hljs\">ERROR:root:Caught Exception!\nTraceback (most recent call last):\n  File \"index.py\", line 5, in &lt;module&gt;\n    print(my_list(3)) # Index out of range\nIndexError: list index out of range\n<\/code><\/pre>\n<p>\u062f\u0631 \u0635\u0648\u0631\u062a\u06cc \u06a9\u0647 \u0627\u0633\u062a\u062b\u0646\u0627\u0647\u0627 \u062a\u0648\u0633\u0637 \u0642\u0627\u0628 \u067e\u0634\u062a\u0647 \u0641\u0639\u0644\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0646\u0634\u0648\u062f\u060c \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0627\u0632 \u062a\u0645\u0627\u0633 \u06af\u06cc\u0631\u0646\u062f\u0647 \u0622\u0646 (\u06cc\u0639\u0646\u06cc \u0641\u0631\u06cc\u0645 \u067e\u0634\u062a\u0647 \u0641\u0631\u0627\u062e\u0648\u0627\u0646) \u0628\u0647 \u062f\u0633\u062a \u0645\u06cc \u0622\u06cc\u062f \u0648 \u0628\u0647 \u0647\u0645\u06cc\u0646 \u062a\u0631\u062a\u06cc\u0628 \u0631\u0648\u06cc \u062a\u0627 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u06cc\u06a9 \u0642\u0627\u0628 \u067e\u0634\u062a\u0647 \u0627\u06cc \u0628\u0631\u0627\u06cc \u0631\u0633\u06cc\u062f\u06af\u06cc \u0628\u0647 \u0627\u0633\u062a\u062b\u0646\u0627 \u067e\u06cc\u062f\u0627 \u06a9\u0646\u062f.  \u0642\u0627\u0628 \u067e\u0634\u062a\u0647 \u062f\u0627\u0631\u0627\u06cc \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u062c\u062f\u06cc\u062f\u062a\u0631\u06cc\u0646 \u0627\u0633\u062a\u062b\u0646\u0627 \u0627\u0633\u062a.<\/p>\n<p>\u0627\u06af\u0631 \u067e\u0634\u062a\u0647 \u0647\u06cc\u0686 \u0627\u0633\u062a\u062b\u0646\u0627\u06cc\u06cc \u0646\u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f\u060c \u06cc\u06a9 \u062a\u0627\u067e\u0644 \u06a9\u0647 \u062f\u0627\u0631\u062f <code>None<\/code> \u0645\u0642\u062f\u0627\u0631 \u0628\u0631\u06af\u0631\u062f\u0627\u0646\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.  \u062f\u0631 \u063a\u06cc\u0631 \u0627\u06cc\u0646 \u0635\u0648\u0631\u062a \u062a\u0627\u0628\u0639 \u0645\u0642\u062f\u0627\u0631 \u0631\u0627 \u0628\u0631\u0645\u06cc \u06af\u0631\u062f\u0627\u0646\u062f <code>type<\/code> (\u0646\u0648\u0639 \u0627\u0633\u062a\u062b\u0646\u0627\u06cc\u06cc \u06a9\u0647 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0645\u06cc \u0634\u0648\u062f)\u060c \u0645\u0642\u062f\u0627\u0631 (\u067e\u0627\u0631\u0627\u0645\u062a\u0631 \u0627\u0633\u062a\u062b\u0646\u0627) \u0648 \u0631\u062f\u06cc\u0627\u0628\u06cc (\u0634\u06cc\u0621 \u0631\u062f\u06cc\u0627\u0628\u06cc \u06a9\u0647 \u067e\u0634\u062a\u0647 \u062a\u0645\u0627\u0633 \u0631\u0627 \u062f\u0631 \u062c\u0627\u06cc\u06cc \u06a9\u0647 \u0627\u0633\u062a\u062b\u0646\u0627 \u062f\u0631 \u0627\u0628\u062a\u062f\u0627 \u0631\u062e \u062f\u0627\u062f\u0647 \u0627\u0633\u062a\u060c \u0645\u062d\u0635\u0648\u0631 \u0645\u06cc \u06a9\u0646\u062f).<\/p>\n<h2 id=\"conclusion\"><span class=\"ez-toc-section\" id=\"%d9%86%d8%aa%db%8c%d8%ac%d9%87\"><\/span>\u0646\u062a\u06cc\u062c\u0647<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0637\u0631\u0627\u062d\u06cc \u0645\u0627\u0698\u0648\u0644 \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u0628\u0633\u06cc\u0627\u0631 \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u0627\u0633\u062a \u0648 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u0622\u0645\u0627\u062f\u0647 \u0628\u0631\u0627\u06cc \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u06af\u0632\u0627\u0631\u0634 \u0627\u0648\u0644\u06cc\u0647 \u0631\u0627 \u0628\u0647 \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 \u06a9\u0648\u0686\u06a9 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u062f.  \u0645\u06cc \u062a\u0648\u0627\u0646 \u0622\u0646 \u0631\u0627 \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0627\u0634\u06cc\u0627\u0621 \u0644\u0627\u06af\u0631 \u0648 \u06af\u0632\u06cc\u0646\u0647 \u0647\u0627\u06cc \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u063a\u0646\u06cc \u0622\u0646\u0647\u0627 \u0628\u0631\u0627\u06cc \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u0627\u0632 \u0646\u06cc\u0627\u0632\u0647\u0627\u06cc \u062d\u062a\u06cc \u0633\u062e\u062a \u062a\u0631\u06cc\u0646 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627 \u06af\u0633\u062a\u0631\u0634 \u062f\u0627\u062f.  \u0639\u0644\u0627\u0648\u0647 \u0628\u0631 \u067e\u06cc\u0627\u0645\u200c\u0647\u0627\u060c \u0645\u0627\u0698\u0648\u0644 \u06af\u0632\u0627\u0631\u0634\u200c\u06af\u06cc\u0631\u06cc \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u062f \u0628\u0631\u0627\u06cc \u062b\u0628\u062a \u0627\u0633\u062a\u062b\u0646\u0627\u0647\u0627 \u0648 \u067e\u0634\u062a\u0647\u200c\u0633\u0627\u0632\u06cc \u0631\u062f\u06cc\u0627\u0628\u06cc\u200c\u0647\u0627 \u0646\u06cc\u0632 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0634\u0648\u062f.  \u0627\u06cc\u0646 \u0622\u0645\u0648\u0632\u0634 \u067e\u0627\u06cc\u0647 \u0631\u0627 \u0628\u0647 \u067e\u0627\u06cc\u0627\u0646 \u0645\u06cc \u0631\u0633\u0627\u0646\u062f \u0631\u0648\u06cc \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0644\u0627\u06af \u062f\u0631 \u067e\u0627\u06cc\u062a\u0648\u0646<\/p>\n<\/div>\n<p><script>\n                        !function(f,b,e,v,n,t,s)\n                        {if(f.fbq)return;n=f.fbq=function(){n.callMethod?\n                        n.callMethod.apply(n,arguments):n.queue.push(arguments)};\n                        if(!f._fbq)f._fbq=n;n.push=n;n.loaded=!0;n.version='2.0';\n                        n.queue=();t=b.createElement(e);t.async=!0;\n                        t.src=v;s=b.getElementsByTagName(e)(0);\n                        s.parentNode.insertBefore(t,s)}(window, document,'script',\n                        'https:\/\/connect.facebook.net\/en_US\/fbevents.js');\n                        fbq('init', '525232124909042');\n                        fbq('track', 'PageView');\n                    <\/script>    (\u0628\u0631\u0686\u0633\u0628\u200c\u0647\u0627 \u0628\u0647 \u062a\u0631\u062c\u0645\u0647)# python<br \/>\n<br \/><br \/>\n<br \/>\u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u062f\u0631 1403-01-25 16:16:03<br \/>\n<\/p>\n\n\n<div class=\"kk-star-ratings kksr-auto kksr-align-center kksr-valign-bottom\"\n    data-payload='{&quot;align&quot;:&quot;center&quot;,&quot;id&quot;:&quot;16475&quot;,&quot;slug&quot;:&quot;default&quot;,&quot;valign&quot;:&quot;bottom&quot;,&quot;ignore&quot;:&quot;&quot;,&quot;reference&quot;:&quot;auto&quot;,&quot;class&quot;:&quot;&quot;,&quot;count&quot;:&quot;0&quot;,&quot;legendonly&quot;:&quot;&quot;,&quot;readonly&quot;:&quot;&quot;,&quot;score&quot;:&quot;0&quot;,&quot;starsonly&quot;:&quot;&quot;,&quot;best&quot;:&quot;5&quot;,&quot;gap&quot;:&quot;5&quot;,&quot;greet&quot;:&quot;\u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0637\u0644\u0628&quot;,&quot;legend&quot;:&quot;0\\\/5 (0 \u0631\u0627\u06cc)&quot;,&quot;size&quot;:&quot;30&quot;,&quot;title&quot;:&quot;\u0627\u0635\u0648\u0644 \u062b\u0628\u062a \u067e\u0627\u06cc\u062a\u0648\u0646&quot;,&quot;width&quot;:&quot;0&quot;,&quot;_legend&quot;:&quot;{score}\\\/{best} ({count} \u0631\u0627\u06cc)&quot;,&quot;font_factor&quot;:&quot;1.25&quot;}'>\n            \n<div class=\"kksr-stars\">\n    \n<div class=\"kksr-stars-inactive\">\n            <div class=\"kksr-star\" data-star=\"1\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"2\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"3\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"4\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"5\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n    \n<div class=\"kksr-stars-active\" style=\"width: 0px;\">\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n<\/div>\n                \n\n<div class=\"kksr-legend\" style=\"font-size: 24px;\">\n            <span class=\"kksr-muted\">\u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0637\u0644\u0628<\/span>\n    <\/div>\n    <\/div>\n","protected":false},"excerpt":{"rendered":"<p><span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 6<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span>\u0645\u0639\u0631\u0641\u06cc \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u0628\u0647 \u0634\u0645\u0627 \u06a9\u0645\u06a9 \u0645\u06cc\u200c\u06a9\u0646\u062f \u062a\u0627 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc\u06cc \u0631\u0627 \u06a9\u0647 \u062f\u0631 \u0637\u0648\u0644 \u0627\u062c\u0631\u0627\u06cc \u06a9\u062f\u062a\u0627\u0646 \u0627\u062a\u0641\u0627\u0642 \u0645\u06cc\u200c\u0627\u0641\u062a\u062f \u0631\u0627 \u067e\u06cc\u06af\u06cc\u0631\u06cc \u06a9\u0646\u06cc\u062f\u060c \u06a9\u0647 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u062f \u062f\u0631 \u0622\u06cc\u0646\u062f\u0647 \u0628\u0631\u0627\u06cc \u0627\u0647\u062f\u0627\u0641 \u0627\u0634\u06a9\u0627\u0644\u200c\u0632\u062f\u0627\u06cc\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0634\u0648\u062f. \u062a\u0635\u0648\u06cc\u0631 \u0628\u0647\u062a\u0631\u06cc \u0627\u0632 \u062c\u0631\u06cc\u0627\u0646 \u0628\u0631\u0646\u0627\u0645\u0647 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f \u0648 \u0628\u0647 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u06a9\u0645\u06a9 \u0645\u06cc \u06a9\u0646\u062f \u062a\u0627 \u0645\u0646\u0628\u0639 \u062e\u0637\u0627\u0647\u0627\u06cc\u06cc \u0631\u0627 \u06a9\u0647 \u062f\u0631 \u062d\u06cc\u0646 \u0627\u062c\u0631\u0627\u06cc \u06a9\u062f \u0634\u0645\u0627 [&hellip;]<\/p>\n","protected":false},"author":3,"featured_media":9162,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1743,620],"tags":[1749,1748,1754,1751,1886,1744,2020,1752],"class_list":["post-16475","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-python","category-programming","tag-python","tag-python-hosting","tag-1754","tag-1751","tag-1886","tag-1744","tag-2020","tag-1752"],"acf":[],"_links":{"self":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/16475","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/users\/3"}],"replies":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/comments?post=16475"}],"version-history":[{"count":0,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/16475\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media\/9162"}],"wp:attachment":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media?parent=16475"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/categories?post=16475"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/tags?post=16475"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}