python3读写excel文件_python3 循环读取excel文件并写入json操作

python3 循环读取excel文件并写入json操作,文件,时间,操作,入时,模板

python3 循环读取excel文件并写入json操作

易采站长站,站长之家为您整理了python3 循环读取excel文件并写入json操作的相关内容。

文件内容:

127fcbc27c84b67c8ec75ebbe8dc3bf8.jpg

excel内容:

44a6b40904ddc1c80080266901ed543b.jpg

代码:import xlrdimport jsonimport operator def read_xlsx(filename): # 打开excel文件 data1 = xlrd.open_workbook(filename) # 读取第一个工作表 table = data1.sheets()[0] # 统计行数 n_rows = table.nrows data = [] # 微信文章属性:wechat_name wechat_id title abstract url time read like number for v in range(1, n_rows-1): # 每一行数据形成一个列表 values = table.row_values(v) # 列表形成字典 data.append({'wechat_name': values[0], 'wechat_id': values[1], 'title': values[2], 'abstract': values[3], 'url': values[4], 'time': values[5], 'read': values[6], 'like': values[7], 'number': values[8], }) # 返回所有数据 return data if __name__ == '__main__': d = [] # 循环打开每个excel for i in range(1, 16): d1 = read_xlsx('./excel data/'+str(i)+'.xlsx') d.extend(d1) # 微信文章属性 # 按时间升序排列 d = sorted(d, key=operator.itemgetter('time')) # 写入json文件 with open('article.json', 'w', encoding='utf-8') as f: f.write(json.dumps(d, ensure_ascii=False, indent=2)) name = [] # 微信id写文件 f1 = open('wechat_id.txt', 'w') for i in d: if i['wechat_id'] not in name: name.append(i['wechat_id']) f1.writelines(i['wechat_id']) f1.writelines('\n') print(len(name))

结果:

8415c0a770b7184f11d5e2fd7435e731.jpg

补充知识:Python mysql数据 读取时间参数 for循环写入Excel文件

最近在利用Python 实现自动化表报时,有个功能是mysql的业务时间是读取模板文件的时间参数,需要用到for循环功能,基本思路是:

1.自动创建一个输出文件的文件夹

2.根据模板文件创建一个新的excel文件到新创建的文件夹中

3.每次写入时返回sheet的最大行数max_row,下次写入时从最大行的下一行开始继续写入

4.每次读取必须为同一个文件

代码如下:#! /usr/bin/env python# -*- coding:utf-8 -*- import MySQLdbfrom openpyxl import load_workbookimport sysimport timeimport os reload(sys)sys.setdefaultencoding('utf8') # 打开数据库连接db = MySQLdb.connect(host="localhost", user="zimu", passwd="zimu", db="xxx", port=0000,charset='utf8') template_file_demo = r"D:\path\demo.xlsx"# makedirs 创建文件时如果路径不存在会创建这个路径output_path = r"D:\output\demo"+"_"+ time.strftime("%Y%m%d", time.localtime()) +"_" + str(int(time.time()))+"\\"os.makedirs(output_path)#创建文件到新创建的文件夹中book_demo = load_workbook(template_file_demo)book_demo.save(output_path + "demo" +"_"+time.strftime("%Y%m%d", time.localtime())+".xlsx")#读取指定文件夹下的文件demo_file = output_path+"demo"+"_"+time.strftime("%Y%m%d", time.localtime())+".xlsx" def savedata(start_time,end_time):demosql = '''select * from demo where start_date<='%s' and end_date>='%s''''%(start_time,end_time) cursor = db.cursor() cursor.execute(demosql) demodata = cursor.fetchall() demo_book = load_workbook(demo_file) demosheet = demo_book['demo'] row_t = demosheet.max_row i = 0 while i < len(demodata): for j in range(0, 8): demosheet.cell(row_t + i + 1, j + 1).value = demodata[i][j] i += 1 demo_book.save(output_path+"demo"+"_"+time.strftime("%Y%m%d", time.localtime())+".xlsx") book_template = load_workbook(template_file_demo)timet = book_template['时间配置']for t in range(2, timet.max_row + 1): # 读取配置表中的时间 savedata(timet.cell(t, 1).value, timet.cell(t, 2).value)

5.模板文件的时间参数设置如下:

d743510abeba6adc006a051a5f96d7d8.jpg以上就是关于对python3 循环读取excel文件并写入json操作的详细介绍。欢迎大家对python3 循环读取excel文件并写入json操作内容提出宝贵意见

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值