码迷,mamicode.com
首页 > 编程语言 > 详细

[python] 日常撸码小case

时间:2019-12-28 16:35:26      阅读:111      评论:0      收藏:0      [点我收藏+]

标签:handle   with   spl   路径   dir   查找   col   strip   怎么   

处理log时遇到一些东东

对log 的处理

  1. 从第二行读起: for line in f.readlines()[1:]
  2. 最后一个元素是个带换行符以及双引号的str,怎么处理呢? .strip()去掉换行符, eval()去掉双引号
  3. 查找如果这一行中有 dip write,就详细分析,但会拿到 a_dip write,怎么办?
    3.1 求助了闪存哈哈哈,嗷神给了提示, 用startwith(), 于是 if dip write in line 改成了 if line.startswith(‘dip write‘)
  4. 需要将 size=10bgm=history 改写成dict
    4.1 urlparse 库可以轻松改dict:
    技术图片
    4.2 合并两个dict,summary = dict(a.items()+b.items())
     with open('/mnt/test_annie/test.log', 'r') as f:
            for line in f.readlines()[1:]:
            # for line in f.readlines():
                if line.startswith('dip write'):
                    useful_list = line.split(' ')
                    new_file_from_log = eval(useful_list[-1].strip())
                    for item in useful_list:
                        if '=' in item:
                            item = dict(urlparse.parse_qsl(item))
                            checkpoint_log = dict(checkpoint_log.items() + item.items())

对dir 的处理

  1. 用 instance.files.keys() 来获取路径下所有的files的path
  2. 用 sorted(instance.files.keys())[-1]来获取最新file的path
  3. 用 os.path.getsize(file_path)来获取file的size
    before_num_file = len(self.instance.files) new_file_path = sorted(self.instance.files.keys())[-1] new_file_size = os.path.getsize(new_file_path)

log 的存储

    cls.fh = logging.FileHandler('/mnt/test_annie/test.log')
    cls.instance.logger.addHandler(cls.fh)

[python] 日常撸码小case

标签:handle   with   spl   路径   dir   查找   col   strip   怎么   

原文地址:https://www.cnblogs.com/vivivi/p/12111634.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!