打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
python 读取excel 循环 / 张生荣

文件内容:

excel内容:

代码:

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 numberfor 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 = []# 循环打开每个excelfor 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))

结果:

补充知识: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 = 0while i < len(demodata):for j in range(0, 8):demosheet.cell(row_t + i + 1, j + 1).value = demodata[i][j]i += 1demo_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.模板文件的时间参数设置如下:

以上这篇python3 循环读取excel文件并写入json操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
python selenium - 利用excel实现参数化
12行代码教会你用python读excel文件,提取数据,生成条形码
Python数据分析入门教程(一):获取数据源
手把手教你用Python替代Mapinfo更快查找两张表中距离最近的点
Python数据分析实战:获取数据
n种方式教你用Python读写Excel等数据文件
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服