Excel文件转换为HTML文件

文章目录


前言

将一个Excel文件转换为HTML文件

安装python包

使用pandas和openpyxl库来实现这个功能

bash 复制代码
pip install pandas openpyxl

python代码

1、首先使用tkinter库中的filedialog模块弹出一个对话框来选择要转换的Excel文件

2、使用pandas库读取该Excel文件并将其转换为HTML格式

3、将生成的HTML内容保存到用户指定的文件中

python 复制代码
# 导入os模块
import os
# 从tkinter库中导入filedialog模块
from tkinter import filedialog
# 从tkinter库中导入Tk模块
from tkinter import Tk
# 导入pandas库,并将其重命名为pd
import pandas as pd

# 定义一个选择文件的函数
def select_file():
    # 创建一个Tk对象
    root = Tk()
    # 隐藏Tk窗口
    root.withdraw()
    # 弹出文件选择对话框,只允许选择Excel文件,并将选择的文件路径赋值给file_path
    file_path = filedialog.askopenfilename(filetypes=[("Excel files", "*.xlsx")])
    # 返回选择的文件路径
    return file_path

# 定义一个保存文件的函数
def save_file():
    # 创建一个Tk对象
    root = Tk()
    # 隐藏Tk窗口
    root.withdraw()
    # 弹出文件保存对话框,设置默认扩展名为.html,并将选择的文件路径赋值给file_path
    file_path = filedialog.asksaveasfilename(defaultextension=".html")
    # 返回选择的文件路径
    return file_path

# 定义一个将Excel文件转换为HTML文件的函数
def excel_to_html(input_file, output_file):
    # 使用pandas读取Excel文件,并将其转换为DataFrame对象
    df = pd.read_excel(input_file, engine='openpyxl')
    # 将DataFrame对象转换为HTML表格,不显示索引和表头
    html = df.to_html(index=False, header=False)
    # 以写入模式打开输出文件,编码为utf-8
    with open(output_file, 'w', encoding='utf-8') as f:
        # 将HTML表格写入输出文件
        f.write(html)

# 定义主函数
def main():
    # 调用select_file函数,选择输入文件,并将文件路径赋值给input_file
    input_file = select_file()
    # 调用save_file函数,选择输出文件,并将文件路径赋值给output_file
    output_file = save_file()
    # 打印输入文件路径
    print("输入文件:", input_file)
    # 打印输出文件路径
    print("输出文件:", output_file)
    # 调用excel_to_html函数,将输入文件转换为HTML文件并保存到输出文件
    excel_to_html(input_file, output_file)

# 如果当前脚本是主程序,则执行main函数
if __name__ == "__main__":
    main()
相关推荐
阿钱真强道3 分钟前
28 Python 分类:不只是画一条线,一文认识支持向量机(SVM)
python·支持向量机·分类·svm·边界·核方法·高维
Jay_Franklin6 分钟前
Python一站式科研工作流:从数据分析到报告生成
开发语言·python·论文笔记
m0_518019488 分钟前
使用Python操作文件和目录(os, pathlib, shutil)
jvm·数据库·python
reasonsummer10 分钟前
【办公类-133-03】20260320_学区化展示PPT_03_“Python”批量gif制作
python·豆包
weixin_4629019713 分钟前
ESP32电压显示
开发语言·javascript·css·python
阿贵---14 分钟前
使用Python进行PDF文件的处理与操作
jvm·数据库·python
winfredzhang15 分钟前
FolderMover Pro用 Python + wxPython 构建安全高速的文件移动工具
python·wxpython·多线程·md5校验·容量筛选·失败回滚·实时进度
551只玄猫15 分钟前
【基于python的金融分析和风险管理 学习笔记】中阶篇 第6章 分析利率和汇率
笔记·python·学习·金融·学习笔记·汇率·利率
小邓睡不饱耶41 分钟前
东方财富网股票数据爬取实战:从接口分析到数据存储
开发语言·爬虫·python·网络爬虫
2401_8916558141 分钟前
GitHub镜像站搭建全攻略技术文章大纲
python·github