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 小时前
【极速部署】Ubuntu24.04+CUDA13.0 玩转 VLLM 0.15.0:预编译 Wheel 包 GPU 版安装全攻略
运维·前端·人工智能·python·ai编程·cuda·vllm
yaoming1682 小时前
python性能优化方案研究
python·性能优化
码云数智-大飞3 小时前
使用 Python 高效提取 PDF 中的表格数据并导出为 TXT 或 Excel
python
biuyyyxxx4 小时前
Python自动化办公学习笔记(一) 工具安装&教程
笔记·python·学习·自动化
极客数模4 小时前
【2026美赛赛题初步翻译F题】2026_ICM_Problem_F
大数据·c语言·python·数学建模·matlab
小鸡吃米…6 小时前
机器学习中的代价函数
人工智能·python·机器学习
Li emily7 小时前
如何通过外汇API平台快速实现实时数据接入?
开发语言·python·api·fastapi·美股
m0_561359677 小时前
掌握Python魔法方法(Magic Methods)
jvm·数据库·python
Ulyanov7 小时前
顶层设计——单脉冲雷达仿真器的灵魂蓝图
python·算法·pyside·仿真系统·单脉冲
2401_838472518 小时前
使用Python进行图像识别:CNN卷积神经网络实战
jvm·数据库·python