python-文件读取及处理

今天业务反应一个问题,给某第三方提供的对账文件出现解析错误,拿来一看发现该文件的明细使用|分割的,但是明细清单中某字段中出现了|,导致解析错误,第三方要求将存量数据检查重发。

我这边写了个简单的程序,扫描存量txt文件,并将分隔符数量不等于14的明细列出。

粗略代码如下:

#读某个路径下所有文件存储
def list_all_files(rootdir):
    import os
    _files = []
    list = os.listdir(rootdir) #列出文件夹下所有的目录与文件
    for i in range(0,len(list)):
           path = os.path.join(rootdir,list[i])
           if os.path.isdir(path):
              _files.extend(list_all_files(path))
           if os.path.isfile(path):
              _files.append(path)
    return _files
#统计字符串中某个字符的出现次数
def countChar(str,ch):
    count = 0 
    for i in range(len(str)):
       # print(i)
        if str[i]==ch:
            count = count + 1
          #  print( "%d:%d" %(i, count))
    return count
    _fs = list_all_files('g:/1/')
    for i in _fs:
        f = open(i, "r")  # 设置文件对象
        print(i+'\n')
        line = f.readline()
        while line:  # 直到读取完文件
            line = f.readline()  # 读取一行文件,包括换行符
            if countChar(line,'|') != 14 :
                print(line)
        f.close()  # 关闭文件

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值