Excel 转化成JSON

Excel 转化成JSON

python 复制代码
import pandas as pd
import json
import os

def excel_to_json(excel_path, sheet_name=0, orient='records', save_path=None):
    """
    将Excel文件转换为JSON格式并可选择保存到文件
    
    参数:
        excel_path: Excel文件路径
        sheet_name: 工作表名称或索引,默认为第一个工作表
        orient: JSON格式取向('records'、'split'、'index'等),默认为'records'
        save_path: JSON文件保存路径,如果为None则不保存文件
    
    返回:
        JSON字符串
    """
    # 读取Excel文件
    df = pd.read_excel(excel_path, sheet_name=sheet_name)
    
    # 处理NaN值,替换为None以确保正确转换为JSON的null
    df = df.where(df.notnull(), None)
    
    # 转换为JSON字符串
    json_str = df.to_json(orient=orient, force_ascii=False, indent=2)
    
    # 如果指定了保存路径,则保存到文件
    if save_path:
        # 确保目录存在
        os.makedirs(os.path.dirname(save_path), exist_ok=True)
        
        # 保存到文件
        with open(save_path, 'w', encoding='utf-8') as f:
            f.write(json_str)
        print(f"JSON文件已保存至: {save_path}")
    
    return json_str

# 使用示例
if __name__ == "__main__":
    # 转换Excel并保存为JSON文件
    json_output = excel_to_json(
        excel_path="data.xlsx",
        sheet_name="Sheet1",
        orient='records',
        save_path="output/data.json"  # 指定保存路径
    )
    
    # 打印部分JSON内容预览
    print("JSON内容预览:")
    print(json_output[:200] + "..." if len(json_output) > 200 else json_output)
相关推荐
小熊出擊3 小时前
【pytest】finalizer 执行顺序:FILO 原则
python·测试工具·单元测试·pytest
tao3556673 小时前
【Python刷力扣hot100】49. Group Anagrams
开发语言·python·leetcode
韩立学长4 小时前
【开题答辩实录分享】以《基于Python的新能源汽车管理系统的设计与实现》为例进行答辩实录分享
python·新能源汽车
Pocker_Spades_A4 小时前
中秋与代码共舞:用Python、JS、Java打造你的专属中秋技术盛宴
python
梁萌4 小时前
自动化测试框架playwright使用
自动化测试·python·ui自动化·playwright
Python×CATIA工业智造5 小时前
Python回调函数中携带额外状态的完整指南:从基础到高级实践
python·pycharm
害恶细君5 小时前
【超详细】使用conda配置python的开发环境
开发语言·python·jupyter·pycharm·conda·ipython
java1234_小锋5 小时前
TensorFlow2 Python深度学习 - TensorFlow2框架入门 - 变量(Variable)的定义与操作
python·深度学习·tensorflow·tensorflow2
我星期八休息6 小时前
C++异常处理全面解析:从基础到应用
java·开发语言·c++·人工智能·python·架构
2401_841495646 小时前
【数据结构】汉诺塔问题
java·数据结构·c++·python·算法·递归·