python应用(3):读取excel文件并导出为json文件

前言

读取excel文件并导出为json文件,便于其他程序调用

一、代码

python 复制代码
# coding=UTF-8
import xlrd
import json

def convert2json(filename,keep_header=False):
    xlrd.Book.encoding = "utf-8" 
    # 打开 Excel 文件
    workbook = xlrd.open_workbook(filename)
    
    # 获取第一个工作表
    worksheet = workbook.sheet_by_index(0)
    
    # 创建一个空列表
    data = []
    
    # 遍历每一行
    for row_index in range(worksheet.nrows):
        # 读取每一行的数据
        row_data = worksheet.row_values(row_index)
        # 将读取到的数据添加到列表中
        data.append(row_data)

    dic = {}
    content = []
    row = len(data)
    column = len(data[0])
    start = 1-int(keep_header)
           
    for i in range(start,row,1):            
        for j in range(column):
            content.append(data[i][j])
        dic[data[i][0]] = content
        content = []

    with open('测试.json', 'w', encoding='utf-8') as file:
        json.dump(dic, file, ensure_ascii=False, indent=2)
    
if __name__ == "__main__":
    convert2json('测试.xls',keep_header=False)

二、说明

高版本的xlrd库只支持读写xls格式的文件,不支持xlsx,否则会报错。(这个有点无语)

需要将表格内容按xls格式另存为,不能只修改文件后缀名。

json.dump(dic, file, ensure_ascii=False, indent=2)

这行代码将读取构建好的字典内容转为json文件并保存,其中ensure_ascii=False用于保留原有字符,否则中文会出现乱码;indent=2将json内容换行缩进2字符,否则所有json内容均在一行内,没有换行导致查看非常不变

start = 1-int(keep_header)

这行代码将"是否保留表头"的布尔值转换为数字,当布尔值为True时从0开始for循环;当布尔值为False时从1开始for循环,这样可以节约for循环部分代码,避免出现过多if else

三、后续更新

后续补充纵向布局excel内容的转换(将for循环顺序调转即可),以及将json文件转为excel文件的代码

相关推荐
东方佑2 分钟前
使用 FastMCP 实现 Word 文档与 JSON 数据互转的 Python 服务
python·json·word
zhanshuo7 分钟前
Python全局变量避坑指南:购物车实战案例解析,轻松掌握作用域陷阱!
python
Dxy12393102167 分钟前
通过XML方式在Word段落前添加空白段落
xml·python·word
等风来不如迎风去35 分钟前
【python】bash: !‘: event not found
chrome·python·bash
Q_Q51100828537 分钟前
python+django/flask+uniapp宠物中心信息管理系统app
spring boot·python·django·flask·uni-app·node.js·php
Nina_71738 分钟前
Day 49 训练
python
yizhimie3740 分钟前
DAY 31 文件的规范拆分和写法
python
skywalk81631 小时前
超强人工智能解决方案套件InfiniSynapse:精准的业务理解、对各种数据源进行全模态联合智能分析--部署安装@Ubuntu22.04 & @Docker
数据库·人工智能·python·docker·infini-synapse
亚林瓜子1 小时前
AWS Lambda Python + AWS Secrets Manager + AWS Aurora Mysql
python·mysql·aws·lambda·aurora·vpc·secrets
船长@Quant1 小时前
量化面试绿皮书:13. 贴错标签的袋子
python·量化绿皮书·量化面试·量化算法