python利用xlwings写入一行或一列Excel数据
from typing import Union
import xlwings as xw
fp = r"C:\Users\user\Desktop\测试.xlsx"
# 打开Excel应用程序
app = xw.App(visible=False) # 后台写入,不展示excel界面
# 打开Excel文件
wb = xw.Book(fp)
新增sheet
# 新增sheet页时,可选择新增位置,由参数before或after控制
sht = wb.sheets.add('result')
写入行
def write_rows(io, sheet: Union[int, str] = 0, row='A1', data=None):
"""
写入一行或多行数据
:param io: Excel文件
:param sheet: sheet,int或者str类型
:param row: 从哪一行开始写入,如:'A1'
:param data: 要写入的数据,str、list或者tuple,e.g. [[1, 9], [2, 8], [3, 7], [4, 6]]
:return:
"""
wb = xw.Book(io)
if isinstance(sheet, str):
sht = wb.sheets(sheet)
else:
sht = wb.sheets[sheet]
sht.range(row).value = data
wb.save()
# 关闭工作簿和Excel应用程序
wb.close()
app.quit()
写入多行时,效果如下:
写入列
def write_cols(io, sheet: Union[int, str] = 0, col='A1', data=None):
"""
写入一列或多列数据
:param io: Excel文件
:param sheet: sheet,int或者str类型
:param col: 哪一列,如:'A1'
:param data: 要写入的数据,str、list或者tuple,e.g. [[1, 2], [3, 4], [5, 6]]
:return:
"""
wb = xw.Book(io)
if isinstance(sheet, str):
sht = wb.sheets(sheet)
else:
sht = wb.sheets[sheet]
sht.range(col).options(transpose=True).value = data
wb.save()
# 关闭工作簿和Excel应用程序
wb.close()
app.quit()
写入多列时,效果如下:
本文来自博客园,仅供参考学习,如有不当之处还望不吝赐教,不胜感激!转载请注明原文链接:https://www.cnblogs.com/rong-z/p/13201864.html
作者:cnblogs用户
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人