文件内容:

excel内容:

代码:

import xlrd

import json

import 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))

结果:

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

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

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

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

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

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

代码如下:

#! /usr/bin/env python

# -*- coding:utf-8 -*-

import MySQLdb

from openpyxl import load_workbook

import sys

import time

import 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.模板文件的时间参数设置如下:

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

时间: 2020-07-14

python3读写excel文件_python3 循环读取excel文件并写入json操作相关推荐

  1. java代码里的JSON格式怎么写好看_python3 循环读取excel文件并写入json操作

    文件内容: excel内容: 代码: import xlrdimport jsonimport operatordef read_xlsx(filename): # 打开excel文件 data1 = ...

  2. python循环读取excel存入列表_python3 循环读取excel文件并写入json操作

    文件内容: excel内容: 代码: import xlrd import json import operator def read_xlsx(filename): # 打开excel文件 data ...

  3. python读excel并写入_python3 循环读取excel文件并写入json操作

    文件内容: excel内容: 代码: import xlrd import json import operator def read_xlsx(filename): # 打开excel文件 data ...

  4. python读取csv文件_python3.0读取csv文件

    创建CSV文件,可以打开excel文件,创建表格以后,另存为csv文件(以逗号分隔的文件) 以文本格式打开,发现是用逗号分隔的 用python读取csv文件,首先要引入一个库:csv import c ...

  5. php循环读取excel每个单元格,php使用PHPexcel类读取excel文件(循环读取每个单元格的数据)...

    error_reporting(E_ALL); date_default_timezone_set('Asia/ShangHai'); include_once('Classes/PHPExcel/I ...

  6. js 读取excel 导入mysql_可以读取EXCEL文件的js代码

    首页给个有中文说明的例子,下面的例子很多大家可以多测试. function readExcel() { var excelApp; var excelWorkBook; var excelSheet; ...

  7. python 读excel中的sheet_python读取excel文件中所有sheet表格

    sales: store: """ (1)用load_workbook函数打开excel文件,返回一个工作簿对象 (2)用工作簿对象获取所有的sheet (3)第一个fo ...

  8. robot framework循环读取excel表操作

    robot framework循环读取excel表操作 1.安装excellibrary,注意python3.7版本,需安装:robotframework-excel,robotframework-e ...

  9. while和for循环读取大文件三种读取文件方式

    目录 While和for循环 读写文件 三种读操作比较 read()读文件 readline()读文件 readlines()读文件 While和for循环 for循环实现猜三次年纪 age = 66 ...

最新文章

  1. Java配置环境变量及其意义
  2. RIP 数据包类型 路由中毒
  3. JavaWeb(三)——Maven的安装、配置及在IDEA中的使用
  4. matlab 低秩矩阵分解,低秩分解的matlab代码看不懂,分解的两个矩阵在哪呀??...
  5. 准备重新回归信息安全产业
  6. python创_Python创建Windows 服务
  7. 企业QQ 增加在线交谈链接
  8. Qt学习笔记-Qt Graphic View Framework
  9. java 心跳程序_Java实现心跳机制的方法
  10. 2021年宁夏省高考成绩查询入口,2021年宁夏高考成绩查询通知【附官网查询入口】...
  11. np.c_和np.r_
  12. 拓端tecdat|R语言中的马尔可夫区制转移(Markov regime switching)模型
  13. 威纶触摸屏使用说明书_你不知道选择工业触摸屏还有这么多技巧?
  14. 9个完整android开源app项目
  15. 学习记录:小程序图片上传至服务器
  16. 计算机的组装与维修的知识点总结,计算机组装与维修教学总结
  17. QQ游戏连连看外挂(VC)
  18. BitTorrent Sync简介
  19. Word制作表格常用操作
  20. Bootstrap自定义上传文件图标样式并使用ajax及formData进行上传

热门文章

  1. ThreadLocal的使用
  2. ActiveMQ添加商品发送消息
  3. MySQL修改存储过程
  4. Java跨平台实现原理及JVM垃圾回收、内存管理实战
  5. 深入理解Java虚拟机-常用vm参数分析
  6. Oracle数据库之安装教程
  7. struts2的bean标签和set标签
  8. 【KVM系列06】Nova 通过 libvirt 管理 QEMU/KVM 虚机
  9. java xpath 命名空间_【转】玩转 XPath 和缺省命名空间(Default Namespaces)
  10. 错误The type XXX is deprecated解决