当前位置: 代码网 > it编程>前端脚本>Python > 使用Python进行Excel文件xls/xlsx/xsv格式互相转换

使用Python进行Excel文件xls/xlsx/xsv格式互相转换

2025年11月26日 Python 我要评论
1. excel文件处理 - 将xls文件转换为xlsx准备环境python版本需要为3.8-3.14(pywin32的要求)通过pip下载pywin32:pip install pywin32复制即

1. excel文件处理 - 将xls文件转换为xlsx

准备环境

python版本需要为3.8-3.14(pywin32的要求)
通过pip下载pywin32:

pip install pywin32

复制即可运行的完整代码

import os
from win32com import client as wc

def convert_xls_to_xlsx(xls_path: str) -> str:
    """
    将单个xls文件转换为xlsx格式,并返回转换后的文件路径
    
    args:
        xls_path (str): xls文件路径
        
    returns:
        str: 转换后的xlsx文件路径
        
    raises:
        filenotfounderror: 如果文件不存在
        valueerror: 如果文件不是xls格式或路径无效
        exception: 转换过程中的其他错误
    """
    # 参数验证
    if not xls_path or not isinstance(xls_path, str):
        raise valueerror("文件路径不能为空且必须是字符串")
    
    # 检查文件是否存在
    if not os.path.exists(xls_path):
        raise filenotfounderror(f"文件不存在: {xls_path}")
    
    # 检查文件扩展名
    if not xls_path.lower().endswith('.xls'):
        raise valueerror(f"文件不是xls格式: {xls_path}")
    
    # 检查文件是否被占用(临时文件)
    if os.path.basename(xls_path).startswith('~'):
        raise valueerror(f"文件可能是临时文件: {xls_path}")
    
    # 检查文件大小(避免处理空文件或损坏文件)
    file_size = os.path.getsize(xls_path)
    if file_size == 0:
        raise valueerror(f"文件为空: {xls_path}")
    
    excel = none
    workbook = none
    
    try:
        # 创建excel应用实例
        excel = wc.dispatch("excel.application")
        excel.visible = false
        excel.displayalerts = false  # 不显示警告对话框
        
        # 打开工作簿
        workbook = excel.workbooks.open(xls_path)
        
        # 生成新的xlsx文件路径
        base_path = os.path.splitext(xls_path)[0]
        new_path = base_path + ".xlsx"
        
        # 处理文件名冲突
        count = 0
        while os.path.exists(new_path):
            count += 1
            new_path = f"{base_path}({count}).xlsx"
        
        # 保存为xlsx格式(51代表xlsx格式)
        workbook.saveas(new_path, 51)
        
        # 验证转换后的文件
        if not os.path.exists(new_path):
            raise exception("转换后的文件未创建成功")
        
        # 检查转换后的文件大小
        if os.path.getsize(new_path) == 0:
            raise exception("转换后的文件为空")
        
        return new_path
        
    except exception as e:
        # 清理可能创建的部分文件
        if 'new_path' in locals() and os.path.exists(new_path):
            try:
                os.remove(new_path)
            except:
                pass
        raise e
        
    finally:
        # 确保资源被正确释放
        try:
            if workbook:
                workbook.close()
        except:
            pass
            
        try:
            if excel:
                excel.quit()
        except:
            pass


def main():
    """主函数:转换单个文件并显示结果"""
    # 直接在代码中设置要转换的文件路径
    xls_file_path = r"d:\excel_files\example.xls"  # 修改为您要转换的xls文件路径
    
    try:
        print(f"开始转换文件: {xls_file_path}")
        
        # 转换文件
        xlsx_path = convert_xls_to_xlsx(xls_file_path)
        
        # 输出成功信息
        print("\n" + "="*50)
        print("✓ 文件转换成功!")
        print(f"原始文件: {xls_file_path}")
        print(f"转换后文件: {xlsx_path}")
        print(f"文件大小: {os.path.getsize(xlsx_path)} 字节")
        print("="*50)
        
    except filenotfounderror as e:
        print(f"✗ 错误: {e}")
        print("请检查文件路径是否正确")
    except valueerror as e:
        print(f"✗ 错误: {e}")
        print("请确保文件是有效的xls文档")
    except exception as e:
        print(f"✗ 转换失败: {e}")
        print("可能是excel应用问题或文件损坏")


if __name__ == "__main__":
    main()

将代码复制到你的python编辑器中,并修改d:\excel_files\example.xls为您需要转换的xls文件路径即可。转换后的xlsx文件与xls文件同名(如果已经存在了同名xlsx文件,将加上(count)后缀以避免冲突)

核心功能代码

xls文件转换为xlsx文件的核心功能代码为:

import os
from win32com import client as wc

excel = wc.dispatch("excel.application")
excel.visible = false
excel.displayalerts = false

workbook = excel.workbooks.open(xls_path)
workbook.saveas(new_path, 51)
workbook.close()

excel.quit()

将xls_path对应的excel工作簿转换为new_path对应的excel工作簿。需要注意的是这个代码本身xls_path可以是xls/xlsx类型的excel文件路径,python代码本身只是起到了读取excel文件的作用。

workbook.saveas(file_name, file_format)中file_format这个参数表示另存为文件的格式。

  • 51: xlopenxmlworkbook - 不含宏的xlsx格式
  • 52: xlopenxmlworkbookmacroenabled - 含宏的xlsm格式
  • 56: xlexcel8 - excel 97-2003的xls格式
  • 6: xlcsv - csv格式
  • 62: xlcsvutf8 - utf-8编码的csv格式
  • 22: xltextmsdos - ms-dos文本格式
  • 42: xlunicodetext - unicode文本格式

如果原xls文件包含宏,需要使用52格式保存为xlsm文件。

2. excel文件处理 - 将xlsx文件转换为xls

准备环境和核心功能代码与项目3相同。

复制即可运行的完整代码

import os
from win32com import client as wc

def convert_xlsx_to_xls(xlsx_path: str) -> str:
    """
    将单个xlsx文件转换为xls格式
    
    args:
        xlsx_path (str): xlsx文件路径
        
    returns:
        str: 转换后的xls文件路径
    """
    if not os.path.exists(xlsx_path):
        raise filenotfounderror(f"文件不存在: {xlsx_path}")
    
    if not xlsx_path.lower().endswith('.xlsx'):
        raise valueerror(f"文件不是xlsx格式: {xlsx_path}")
    
    excel = none
    workbook = none
    
    try:
        excel = wc.dispatch("excel.application")
        excel.visible = false
        excel.displayalerts = false
        
        workbook = excel.workbooks.open(xlsx_path)
        
        base_path = os.path.splitext(xlsx_path)[0]
        new_path = base_path + ".xls"
        
        count = 0
        while os.path.exists(new_path):
            count += 1
            new_path = f"{base_path}({count}).xls"
        
        # 56: xlexcel8 (excel 97-2003格式)
        workbook.saveas(new_path, 56)
        
        return new_path
        
    finally:
        if workbook:
            workbook.close()
        if excel:
            excel.quit()

def main():
    xlsx_file_path = r"d:\excel_files\example.xlsx"  # 修改为您的xlsx文件路径
    
    try:
        print(f"开始转换文件: {xlsx_file_path}")
        xls_path = convert_xlsx_to_xls(xlsx_file_path)
        print(f"✓ 转换成功: {xls_path}")
    except exception as e:
        print(f"✗ 转换失败: {e}")

if __name__ == "__main__":
    main()

将代码复制到你的python编辑器中,并修改d:\excel_files\example.xlsx为您需要转换的xlsx文件路径即可。转换后的xls文件与xlsx文件同名(如果已经存在了同名xls文件,将加上(count)后缀以避免冲突)

3. excel文件处理 - 将xls文件转换为csv

准备环境和核心功能代码与项目3相同。

复制即可运行的完整代码

import os
from win32com import client as wc

def convert_xls_to_csv(xls_path: str) -> str:
    """
    将单个xls文件转换为csv格式
    
    args:
        xls_path (str): xls文件路径
        
    returns:
        str: 转换后的csv文件路径
    """
    if not os.path.exists(xls_path):
        raise filenotfounderror(f"文件不存在: {xls_path}")
    
    if not xls_path.lower().endswith('.xls'):
        raise valueerror(f"文件不是xls格式: {xls_path}")
    
    excel = none
    workbook = none
    
    try:
        excel = wc.dispatch("excel.application")
        excel.visible = false
        excel.displayalerts = false
        
        workbook = excel.workbooks.open(xls_path)
        
        base_path = os.path.splitext(xls_path)[0]
        new_path = base_path + ".csv"
        
        count = 0
        while os.path.exists(new_path):
            count += 1
            new_path = f"{base_path}({count}).csv"
        
        # 6: xlcsv (csv格式)
        workbook.saveas(new_path, 6)
        
        return new_path
        
    finally:
        if workbook:
            workbook.close()
        if excel:
            excel.quit()

def main():
    xls_file_path = r"d:\excel_files\example.xls"  # 修改为您的xls文件路径
    
    try:
        print(f"开始转换文件: {xls_file_path}")
        csv_path = convert_xls_to_csv(xls_file_path)
        print(f"✓ 转换成功: {csv_path}")
    except exception as e:
        print(f"✗ 转换失败: {e}")

if __name__ == "__main__":
    main()

将代码复制到你的python编辑器中,并修改d:\excel_files\example.xls为您需要转换的xls文件路径即可。转换后的csv文件与xls文件同名(如果已经存在了同名csv文件,将加上(count)后缀以避免冲突)

4. excel文件处理 - 将xlsx文件转换为csv

准备环境和核心功能代码与项目3相同。

复制即可运行的完整代码

import os
from win32com import client as wc

def convert_xlsx_to_csv(xlsx_path: str) -> str:
    """
    将单个xlsx文件转换为csv格式
    
    args:
        xlsx_path (str): xlsx文件路径
        
    returns:
        str: 转换后的csv文件路径
    """
    if not os.path.exists(xlsx_path):
        raise filenotfounderror(f"文件不存在: {xlsx_path}")
    
    if not xlsx_path.lower().endswith('.xlsx'):
        raise valueerror(f"文件不是xlsx格式: {xlsx_path}")
    
    excel = none
    workbook = none
    
    try:
        excel = wc.dispatch("excel.application")
        excel.visible = false
        excel.displayalerts = false
        
        workbook = excel.workbooks.open(xlsx_path)
        
        base_path = os.path.splitext(xlsx_path)[0]
        new_path = base_path + ".csv"
        
        count = 0
        while os.path.exists(new_path):
            count += 1
            new_path = f"{base_path}({count}).csv"
        
        # 6: xlcsv (csv格式)
        workbook.saveas(new_path, 6)
        
        return new_path
        
    finally:
        if workbook:
            workbook.close()
        if excel:
            excel.quit()

def main():
    xlsx_file_path = r"d:\excel_files\example.xlsx"  # 修改为您的xlsx文件路径
    
    try:
        print(f"开始转换文件: {xlsx_file_path}")
        csv_path = convert_xlsx_to_csv(xlsx_file_path)
        print(f"✓ 转换成功: {csv_path}")
    except exception as e:
        print(f"✗ 转换失败: {e}")

if __name__ == "__main__":
    main()

将代码复制到你的python编辑器中,并修改d:\excel_files\example.xlsx为您需要转换的xlsx文件路径即可。转换后的csv文件与xlsx文件同名(如果已经存在了同名csv文件,将加上(count)后缀以避免冲突)

5. excel文件处理 - 将csv文件转换为xls

准备环境和核心功能代码与项目3相同。

复制即可运行的完整代码

import os
from win32com import client as wc

def convert_csv_to_xls(csv_path: str) -> str:
    """
    将单个csv文件转换为xls格式
    
    args:
        csv_path (str): csv文件路径
        
    returns:
        str: 转换后的xls文件路径
    """
    if not os.path.exists(csv_path):
        raise filenotfounderror(f"文件不存在: {csv_path}")
    
    if not csv_path.lower().endswith('.csv'):
        raise valueerror(f"文件不是csv格式: {csv_path}")
    
    excel = none
    workbook = none
    
    try:
        excel = wc.dispatch("excel.application")
        excel.visible = false
        excel.displayalerts = false
        
        workbook = excel.workbooks.open(csv_path)
        
        base_path = os.path.splitext(csv_path)[0]
        new_path = base_path + ".xls"
        
        count = 0
        while os.path.exists(new_path):
            count += 1
            new_path = f"{base_path}({count}).xls"
        
        # 56: xlexcel8 (excel 97-2003格式)
        workbook.saveas(new_path, 56)
        
        return new_path
        
    finally:
        if workbook:
            workbook.close()
        if excel:
            excel.quit()

def main():
    csv_file_path = r"d:\excel_files\example.csv"  # 修改为您的csv文件路径
    
    try:
        print(f"开始转换文件: {csv_file_path}")
        xls_path = convert_csv_to_xls(csv_file_path)
        print(f"✓ 转换成功: {xls_path}")
    except exception as e:
        print(f"✗ 转换失败: {e}")

if __name__ == "__main__":
    main()

将代码复制到你的python编辑器中,并修改d:\excel_files\example.csv为您需要转换的csv文件路径即可。转换后的xls文件与csv文件同名(如果已经存在了同名xls文件,将加上(count)后缀以避免冲突)

6. excel文件处理 - 将csv文件转换为xlsx

准备环境和核心功能代码与项目3相同。

复制即可运行的完整代码

import os
from win32com import client as wc

def convert_csv_to_xlsx(csv_path: str) -> str:
    """
    将单个csv文件转换为xlsx格式
    
    args:
        csv_path (str): csv文件路径
        
    returns:
        str: 转换后的xlsx文件路径
    """
    if not os.path.exists(csv_path):
        raise filenotfounderror(f"文件不存在: {csv_path}")
    
    if not csv_path.lower().endswith('.csv'):
        raise valueerror(f"文件不是csv格式: {csv_path}")
    
    excel = none
    workbook = none
    
    try:
        excel = wc.dispatch("excel.application")
        excel.visible = false
        excel.displayalerts = false
        
        workbook = excel.workbooks.open(csv_path)
        
        base_path = os.path.splitext(csv_path)[0]
        new_path = base_path + ".xlsx"
        
        count = 0
        while os.path.exists(new_path):
            count += 1
            new_path = f"{base_path}({count}).xlsx"
        
        # 51: xlopenxmlworkbook (不含宏的xlsx)
        workbook.saveas(new_path, 51)
        
        return new_path
        
    finally:
        if workbook:
            workbook.close()
        if excel:
            excel.quit()

def main():
    csv_file_path = r"d:\excel_files\example.csv"  # 修改为您的csv文件路径
    
    try:
        print(f"开始转换文件: {csv_file_path}")
        xlsx_path = convert_csv_to_xlsx(csv_file_path)
        print(f"✓ 转换成功: {xlsx_path}")
    except exception as e:
        print(f"✗ 转换失败: {e}")

if __name__ == "__main__":
    main()

将代码复制到你的python编辑器中,并修改d:\excel_files\example.csv为您需要转换的csv文件路径即可。转换后的xlsx文件与csv文件同名(如果已经存在了同名xlsx文件,将加上(count)后缀以避免冲突)

以上就是使用python进行excel文件xls/xlsx/xsv格式互相转换的详细内容,更多关于python文件格式xls/xlsx/xsv互转的资料请关注代码网其它相关文章!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2026  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com