免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: zhaiyuzhen
打印 上一主题 下一主题

[文本处理] 如何检索持续更新日志中的关键词 [复制链接]

论坛徽章:
7
申猴
日期:2014-12-21 13:57:24巳蛇
日期:2014-12-25 22:27:08申猴
日期:2015-01-19 08:07:36辰龙
日期:2015-02-04 11:40:06处女座
日期:2015-02-04 11:40:412015年亚洲杯之卡塔尔
日期:2015-03-06 12:01:322015年亚洲杯之乌兹别克斯坦
日期:2015-03-31 13:43:57
11 [报告]
发表于 2016-07-30 21:20 |只看该作者
试试这个
  1. import sys
  2. import pickle
  3. import re

  4. # save last pos
  5. last_file = 'check.pkl'
  6. if len(sys.argv) < 3:
  7.     print("Usage: python check.py log key1 key2 ... keyn")
  8.     sys.exit(1)

  9. log_file = open(sys.argv[1])
  10. key = []
  11. for i in sys.argv[2:]:
  12.     key.append(i)

  13. with open(last_file, 'ab+') as f:
  14.     if f.tell():
  15.         f.seek(0)
  16.         last_data = pickle.load(f)
  17.     else:
  18.         last_data = {"log_seek": 0}

  19. log_file.seek(last_data['log_seek'])
  20. print(">>>Starting...\n")
  21. for line in log_file:
  22.     for i in key:
  23.         if re.search(i, line):
  24.             print("Alert: find key:{} in {}".format(i, line), end='')

  25. print("\n>>>Finished.")
  26. last_data['log_seek'] = log_file.tell()

  27. # save pos
  28. with open(last_file, 'wb') as f:
  29.     pickle.dump(last_data, f)
复制代码

check.zip

536 Bytes, 下载次数: 11

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP