在Python中读取和打印与USB相关的var日志消息
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了在Python中读取和打印与USB相关的var日志消息,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1121字,纯文字阅读大概需要2分钟。
内容图文
![在Python中读取和打印与USB相关的var日志消息](/upload/InfoBanner/zyjiaocheng/677/0b619de57efb46198c290b39f4efa735.jpg)
我想打印在Ubuntu中创建的日志消息中与USB相关的行.这是我的代码:
>>> import re
>>> fd = open("/var/log/syslog.1", "r")
>>> for lines in fd:
... if re.match("usb", lines):
... print lines
(顺便说一下,我不确定syslog.1文件是否正确.但是,我确实在其中找到了很多消息,其中一些消息与usb有关)
解决方法:
对于最新消息,您需要/ var / log / syslog-/var/log/syslog.1基本上是较旧消息的备份.
阻止代码工作的原因是您使用的是re.match()而不是re.search()-从这些链接的文档中可以看到,re.match()仅在搜索文本的开头匹配.
但是实际上,您根本不需要使用正则表达式.这是您的代码的替代方法:
>>> with open("/var/log/syslog") as f:
... for line in f:
... if "usb" in line.lower():
... print line
...
这里有些不同:
>我们正在使用with context manager打开文件.即使出现问题,这也可以帮助Python清理并关闭文件,这是一个很好的习惯.
>按照Python的常规,我们将文件变量称为f. fd会使阅读您的代码的人认为您正在谈论的是file descriptor,这不是同一回事.
>因为它只包含一行,所以我们将字符串变量称为line,而不是lines.
>而不是使用正则表达式,我们可以只检查“ usb”是否在某行中(并且在检查之前,我们正在将该行转换为小写,以便我们也可以在原始行中捕获“ USB”.
内容总结
以上是互联网集市为您收集整理的在Python中读取和打印与USB相关的var日志消息全部内容,希望文章能够帮你解决在Python中读取和打印与USB相关的var日志消息所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。