Advertisement
Guest User

Untitled

a guest
Jul 26th, 2018
165
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Python 4.20 KB | None | 0 0
  1. import string
  2. import re
  3.  
  4. allLogs = r"""2018-07-24 00:01:33,711 WARN  [r3223r2r3] [] [] [ewqrwerwer] [ewfwefwef] - Failed;
  5. 2018-07-24 00:01:33,712 DEBUG [r3223r2r3] [] [] [ewqrwerwer] [ewfwefwef] - Sample log
  6. 2018-07-24 00:02:33,712 DEBUG [r3223r2r3] [] [] [ewqrwerwer] [ewfwefwef] - Sample log
  7. 2018-07-24 00:20:33,830 DEBUG [r3223r2r3] [] [] [ewqrwerwer] [ewfwefwef] - Sample log
  8. 2018-07-24 00:20:37,731 DEBUG [r3223r2r3] [] [] [3r2r32r] [c.i.s.h.r.i.RssNewsServiceImpl] - 3r232r
  9. 2018-07-24 10:33:45,852 ERROR [r3223r2r3] [fgd] [gr] [reger] [regre] - Sample log
  10. javax.servlet.ServletException: Something bad happened
  11.    at com.example.myproject.OpenSessionInViewFilter.doFilter(OpenSessionInViewFilter.java:60)
  12.    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
  13.    at com.example.myproject.ExceptionHandlerFilter.doFilter(ExceptionHandlerFilter.java:28)
  14.    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
  15.    at com.example.myproject.OutputBufferFilter.doFilter(OutputBufferFilter.java:33)
  16.    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
  17.    at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:388)
  18.    at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216)
  19.    at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:182)
  20.    at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:765)
  21.    at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:418)
  22.    at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
  23.    at org.mortbay.jetty.Server.handle(Server.java:326)
  24.    at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:542)
  25.    at org.mortbay.jetty.HttpConnection$RequestHandler.content(HttpConnection.java:943)
  26.    at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:756)
  27.    at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:218)
  28.    at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:404)
  29.    at org.mortbay.jetty.bio.SocketConnector$Connection.run(SocketConnector.java:228)
  30.    at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:582)
  31. Caused by: com.example.myproject.MyProjectServletException
  32.    at com.example.myproject.MyServlet.doPost(MyServlet.java:169)
  33.    at javax.servlet.http.HttpServlet.service(HttpServlet.java:727)
  34.    at javax.servlet.http.HttpServlet.service(HttpServlet.java:820)
  35.    at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:511)"""
  36.  
  37. keyPattern = re.compile(r"(?P<timestamp>\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2},\d{3})")
  38. valuePatternWithErrorMessage = re.compile(r"(?P<level>INFO|ERROR|WARN|TRACE|DEBUG|FATAL)\s+\[(?P<firstSquareBrackets>[^\]]*)]\s+\[(?P<secondSquareBrackets>[^\]]*)]\s+\[(?P<thirdSquareBrackets>[^\]]*)]\s+\[(?P<fourthSquareBrackets>[^\]]*)]\s+\[(?P<fifthSquareBrackets>[^\]]*)] - (?P<textMessage>.*?)(?=\Z|;\s+|\n)|(?P<exception>^.+Exception: .+)|(?P<stacktrace>^\s+at .+)|(^\s+... \d+ more)|(^\s*Caused by:.+)")
  39. valuePatternWithoutErrorMessage = re.compile(r"(?P<level>INFO|ERROR|WARN|TRACE|DEBUG|FATAL)\s+\[(?P<firstSquareBrackets>[^\]]*)]\s+\[(?P<secondSquareBrackets>[^\]]*)]\s+\[(?P<thirdSquareBrackets>[^\]]*)]\s+\[(?P<fourthSquareBrackets>[^\]]*)]\s+\[(?P<fifthSquareBrackets>[^\]]*)] - (?P<textMessage>.*?)(?=\Z|;\s+|\n)")
  40.  
  41. keyLogslist = keyPattern.findall(allLogs)
  42.  
  43. #из лога вырезается timestamp и перед level оставляется пробел,
  44. #разделение идет по \n вместе с этим пробелом
  45. valueLogs = keyPattern.sub("",allLogs)
  46. valueLogslist = valueLogs.split("\n ")
  47.  
  48. logDict = dict(zip(keyLogslist, valueLogslist))
  49.  
  50. for keysTimestamp in keyLogslist:
  51.     match = valuePatternWithErrorMessage.search(logDict[keysTimestamp])
  52.     if match:
  53.         logDict[keysTimestamp] = match.groupdict()
  54.     else:            
  55.         match = valuePatternWithoutErrorMessage.search(logDict[keysTimestamp])
  56.         if match:
  57.             logDict[keysTimestamp] = match.groupdict()
  58.         else:
  59.             logDict[keysTimestamp] = "None"
  60.  
  61. print(logDict)
  62. print(len(logDict))
  63. print(type(logDict))
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement