Python开发练习-查找目标文件夹内所有Excel表,按月份统计业务量

该博客介绍了如何使用Python遍历指定文件夹,查找所有Excel文件,并对其中的业务量进行按月份的统计分析。统计结果将汇总写入文本文档。同时,作者提供200G学习资源及免费解决小型任务服务。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

查找目标文件夹内所有的Excel文件,按月份统计相关业务量,并输出到文本文档。

import time
import os
import xlrd
import copy
import pathlib
import datetime
import sys
import collections

def getusefile():
    #查当前目录下所有xls xlsx文件,返回文件名列表
    usefile=[]
    excelfile=sorted(pathlib.Path('.').glob('*.xls*'))
    usefile=[str(tpfile) for tpfile in excelfile]
    return copy.deepcopy(usefile)              
    

def rdusefile(fileName):
    #读一个文件,并在文件单元格中查找目标数据,如果找到就返回文件名及数据
    data=xlrd.open_workbook(fileName)           #打开当前目录下名为 fileName 的文档
    worksheets = data.sheet_names()             #返回book中所有工作表的名字
    #打开excel文件的第filenum张表
    sheet_1=data.sheets()[0]                    #通过索引顺序获取sheet表
    nrows=sheet_1.nrows                         #获取该sheet中的有效行数
    ncols=sheet_1.ncols                         #获取该sheet中的有效列数
    getdata=[]
    #读取文件数据
    for i in range(1,nrows-1):
        tep1=[]
        tep1=sheet_1.row(i)[2].value
        getdata.append(tep1)
        
    return copy.deepcopy(getdata)

newdir=os.path.join(os.getcwd(),'new')
os.chdir(newdir)
filelist=getusefile()
out=[]
for file0 in filelist:
    out1={}
    finddata=rdusefile(file0)
    print('号码: ',file0.split('.')[0],' 总数量: ',len(finddata))
    out1['haoma']=file0.split('.')[0]
    out1['shuliang']=len(finddata)
    findall=[cc[:7] for cc in finddata]
    a=dict(collections.Counter(findall))
    out1['data']=a
    out.append(out1)
    print(a)
    print('--'*30)
    
with open('out1.txt','w')as f:
    yue=list(out[0].get("data").keys())
    ahm,asl='号码'+'\t','总数量'+'\t'
    for cc in out:
        ahm=ahm+cc.get('haoma')+'\t'
        asl=asl+str(cc.get('shuliang'))+'\t'
    f.write(ahm+'\n')
    f.write(asl+'\n')
    for cc in yue:
        agy=cc+'\t'
        for ct in out:
            agy=agy+str(ct.get('data').get(str(cc)))+'\t'
        f.write(agy+'\n')

输出1:
在这里插入图片描述

文本输出2:

在这里插入图片描述
关注Python开发练习,200G学习资源免费送,还可以免费处理2.5小时以内的各类小Task。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值