Python3学习(三十八):如何遍历一个目录下的同类型文件(csv、log等)

背景:

最近需要对一些csv日志进行数据格式转换,转化后接入统一的ELK日志。

但是csv文件比较繁多,当大小每到21M的时候,就会根据时间写入到新的csv文件中,一天将近有1000+个文件。

那么如何对某目录下的所有同类型文件进行遍历操作呢?我们以csv文件为例。

import re
import os
import json
import codecs

path = '/home/liao/python/csv'   #你需要遍历的文件目录,比如该目录下有a.csv,b.csv,c.csv
files =  os.listdir(path)
files_csv = list(filter(lambda x:x[-4:]=='.csv', files))

def data_handle():
    for i in range(len(files_csv)):
        with codecs.open('/home/liao/python/csv/{0}'.format(files_csv[i]), 'r') as data_log:
        for line in data_log: #针对每行数据进行处理
            xxxxxxxxxxxxxxxxxxxxxxxxx

上述代码的一些解释:

os.listdir() 方法用于返回指定的文件夹包含的文件或文件夹的名字的列表。

filter(函数,序列)函数用于过滤序列,过滤掉不符合条件的元素,返回由符合条件元素组成的新列表。

lambda作为一个表达式,定义了一个匿名函数。

filter第一个参数为函数的情形,如果function(item)为True,则满足过滤条件。此时的lambda函数的形式是: lambda x: expression(x)

小例子:

filter(lambda x: x, [-1, 0, 1]) #[-1, 1]

filter(lambda x: not x, [-1, 0, 1]) #[0]

filter(lambda x: x[-4:]=='.csv', files) #文件的最后四个字符为.csv

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

猪笨是念来过倒

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值