python - How do I format logs so they print out in columns? -


मेरे पास एक प्रोजेक्ट है जहां विभिन्न धागे और फ़ंक्शन समान StreamHandler () लॉग इन कर रहे हैं कंसोल का उपयोग करते हुए कस्टम लॉगलवेल्स में से कुछ कस्टम हैं

मेरा लॉग करने के लिए प्रारूपित है:

  streamformatter = logging.Formatter (fmt = '% (levelname) s: \ t% (threadName) s: \ t% (FuncName) s: \ t \ t% (message) s ', datefmt ='% H:% M:% S ')  

यह मेरा लॉग डिफ़ॉल्ट रूप से बनाता है इस तरह विकृत जहां यह वास्तव में देखने के लिए बहुत आसान नहीं है या जब यह देखने के लिए आसान है कि किस समारोह को बुलाया जा रहा है और किस धागे से।

  जानकारी: COM14-fwcif-listener: _receive_v32: my_success: 24 लाइनों को फ़ॉर्मेटर भेजना DB_TRACE: COM14-fwcif-श्रोता: _format_and_log_v32: { "शीघ्र": "undef-COM14", "x_type": "tracelogentry", "y_time": १३९२६९५५०६.०,४४,५८३, "z_msg": "...."} जानकारी: COM13- fwutil-श्रोता: _receive_v32: my_success: { "शीघ्र": "undef-COM13", "x_type": COM13-fwutil-श्रोता: _format_and_log_v32 "tracelogentry", "y_time": DB_TRACE fORMATTER करने के लिए 10 लाइनों भेजा जा रहा है १३९२६९५५०७.३,५६,७१४, "z_msg ":" .... "} जानकारी: मेनथाइट: _parse: my_resolve 4.9784979820251465 सेकंड और 29 बनाम 8 प्रयासों MY_INFO: मा InThread: _parse: सीएमडी के लिए my_success "trig" = & gt; & gt; "तैयार नही"। COM12.ISREADY अब सच जानकारी पर सेट: MainThread: भेजें: my_success लॉक जारी किया जा रहा है: & lt; _thread.RLock स्वामी = 7512 गणना = 1 & gt; साथ cmd "प्रारूप c:" और राज्य COM12.ISREADY = झूठी जानकारी: COM12-fwmain-श्रोता: _receive_v32: my_success: COM12-fwmain-श्रोता: _format_and_log_v32: S65 के आधार पर विभाजित लाइनों की संख्या 2 16 के कुल लाइनों जानकारी है my_resolve " S65 & gt; " COM12.lastlinefragment जानकारी के रूप में जोड़ा गया: COM12-fwmain-listener: _format_and_log_v32: my_success: प्रवेश करने के लिए 575 वर्ण लिखे गए हैं। शीघ्र और प्रकार का पता चला है "S65"; और "replylogentry: प्रारूप" DB_REPLY: COM12-fwmain-श्रोता: _format_and_log_v32: { "शीघ्र": "S65 & gt;", "x_type": "replylogentry: प्रारूप", "y_time": १३९२६९५५१०.४१,३०२, "z_msg": "... "} INFO: MainThread: _parse: my_resolve" format "= & gt; स्ट्रिंग में" अज्ञात कमांड "के लिए खोज" ... " 

प्रत्येक टोकन की चौड़ाई निश्चित रूप से कॉलोन में लॉग आउटपुट बनाने के लिए इस तरह streamformatter में निर्दिष्ट किया जा सकता है:

  Streamformatter = logging.Formatter (fmt = '% (levelname) -10s:% (धागेनाम) -20 s:% (funcName) -20 s:% (message) s, datefmt ='% H:% M:% S ' )  

Comments

Popular posts from this blog

import - Python ImportError: No module named wmi -

Editing Python Class in Shell and SQLAlchemy -

c# - MySQL Parameterized Select Query joining tables issue -