Python 给 Excel 写入数据的四种方法

一、使用 openpyxl 库

openpyxl 是一个专门用于读写 Excel 2010 xlsx/xlsm/xltx/xltm 文件的 Python 库,尤其适合需要修改现有 Excel 文件时使用。

复制代码
#python复制代码
from openpyxl import Workbook
# 创建一个新的工作簿
wb = Workbook()
# 获取默认的工作表
ws = wb.active
# 写入数据
ws['A1'] = '姓名'
ws['B1'] = '成绩'
ws['A2'] = '小明'
ws['B2'] = 88
ws['A3'] = '小红'
ws['B3'] = 92
# 保存文件
wb.save('学生成绩.xlsx')
代码说明Workbook() 创建一个新的工作簿对象。wb.active 获取当前活动的工作表。ws['A1'] = '姓名' 将 "姓名" 写入 A1 单元格。wb.save('学生成绩.xlsx') 将工作簿保存为指定的文件名。

二、使用 xlsxwriter 库

xlsxwriter 是一个功能强大的库,能够创建 Excel xlsx 文件并支持丰富的格式化功能,单行进行写入。

复制代码
python复制代码
import xlsxwriter

# 创建新的工作簿
workbook = xlsxwriter.Workbook('销售数据.xlsx')

# 添加一个工作表
worksheet = workbook.add_worksheet()

# 写入数据
data = [
    ['月份', '销售额'],
    ['一月', 150],
    ['二月', 200],
    ['三月', 300],
]

row = 0
for item in data:
    worksheet.write_row(row, 0, item)
    row += 1

# 创建图表
chart = workbook.add_chart({'type': 'column'})
chart.add_series({
    'name': '销售额',
    'categories': '=Sheet1!$A$2:$A$4',
    'values': '=Sheet1!$B$2:$B$4',
})
worksheet.insert_chart('D2', chart)

# 关闭工作簿
workbook.close()
代码说明xlsxwriter.Workbook('销售数据.xlsx') 创建新的工作簿。worksheet.write_row(row, 0, item) 将数据行写入工作表。workbook.add_chart() 创建一个图表对象,并设置数据系列。

三、使用 pandas 库

pandas 是一个极为流行的数据分析工具,它使得处理 Excel 文件变得简单而高效。

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

# 创建一个 DataFrame
data = {
    '姓名': ['小明', '小红', '小刚'],
    '年龄': [22, 23, 21],
    '城市': ['北京', '上海', '广州'],
}
df = pd.DataFrame(data)

# 将 DataFrame 写入 Excel 文件
df.to_excel('用户信息.xlsx', sheet_name='Sheet1', index=False)
代码说明pd.DataFrame(data) 创建一个 DataFrame 对象,用于存储数据。df.to_excel('用户信息.xlsx', sheet_name='Sheet1', index=False) 将数据写入 Excel 文件,指定工作表名称。

四、使用 win32com 库 (Windows Only)

win32com 库允许你直接控制 Excel 应用程序。如果你需要在已有的 Excel 文件中添加数据,这个库会很有用。

python复制代码import win32com.client

打开 Excel 应用程序

excel = win32com.client.Dispatch("Excel.Application")

打开工作簿

workbook = excel.Workbooks.Open("已有文件.xlsx")

获取工作表

worksheet = workbook.Sheets("Sheet1")

写入数据

worksheet.Cells(1, 1).Value = "新数据"

保存文件

workbook.Save()

关闭 Excel 应用程序

excel.Quit()

代码说明win32com.client.Dispatch("Excel.Application") 启动 Excel 应用。workbook.Save() 保存对工作簿的更改。

相关推荐
IT古董4 分钟前
全面理解 Corepack:Node.js 的包管理新时代
前端·node.js·corepack
学习3人组9 分钟前
清晰地说明 NVM、NPM 和 NRM 在 Node.js 开发过程中的作用
前端·npm·node.js
矢心17 分钟前
setTimeout 和 setInterval:看似简单,但你不知道的使用误区
前端·javascript·面试
猫头虎26 分钟前
永久免费白嫖多个域名,一键托管Cloudflare,免费申请SSL加密证书,轻松建站、搭建线路伪装
服务器·开发语言·网络·数据库·python·网络协议·ssl
沙虫一号26 分钟前
线上python问题排查思路
后端·python
一枚前端小能手32 分钟前
🧭 使用历史记录 API - SPA导航与状态管理的完整指南
前端·javascript
用户479492835691535 分钟前
从字符串满天飞到优雅枚举:JavaScript 常量管理的几种姿势
前端·javascript
qq_4152162536 分钟前
Vue3+vant4+Webpack+yarn项目创建+vant4使用注意明细
前端·webpack·node.js
李建军1 小时前
ASP.NET Core Web 应用SQLite数据连接显示(1)
前端
耀耀切克闹灬1 小时前
word文档转html(mammoth )
前端