当前位置: 首页 > article >正文

python-读写Excel:xlwings库操作

几种操作Excel的python库对比

安装:pip install xlwings

目录

APP实例化对象

工作薄对象

创建工作薄

打开工作薄

工作薄属性

工作表对象

新增工作表

复制表

获取工作表对象

工作表属性

删除和清除表数据及表格式

工作表行高列宽(自动调整)

单元格对象

获取单元格对象

1、字母表示法

2、坐标法

3、切片法

单元格属性

单元格插入内容

name:给单元格命名

value:修改或写入文本内容

add_hyperlink:添加超链接

pictures.add:给单元格添加图片

api.AddComment:添加批注

formula:添加或修改函数表达式

添加统计图表

单元格数据类型设置

  ​编辑

单元格样式设置

autofit:设置单元格自适应宽高

Font:字体样式

Borders:边框样式

api.HorizontalAlignment:单元格对齐方式

合并和取消合并单元格

单元格颜色设置

保存退出操作

将Excel转为PDF文件

保存

关闭和退出


APP实例化对象

参数:visible表示实例化的对象是否可见(值为True时会调用系统默认设置打开Excel文件的程序,如打开wps),add_book表示是否在这个工作簿中默认新增工作表。

import xlwings as xw
app = xw.App(visible=False, add_book=False)  
app.display_alerts = False  # 关闭提示信息
app.screen_updating = False  # 关闭显示更新

工作薄对象

创建工作薄

workbook = app.books.add()   # 创建新的工作簿

打开工作薄

workbook = app.books.open(r'C:\Users\Administrator\Desktop\ceshi.xls')  # 打开指定的工作簿

工作薄属性

print(workbook.name)  # 返回工作簿名字

print(workbook.sheets)  # 返回工作薄中所有sheet表的列表,列表内容为所有工作表对象
for sh_name in workbook.sheets:
    print(sh_name.name)

print(workbook.app)  # 返回工作簿所在的App对象[Excel程序]

工作表对象

新增工作表

创建新的sheet工作表对象,可选before或者after参数,指定插入表格的位置在指定表之前或之后。

workbook.sheets.add('工资表', before='Sheet3') 

复制表

参数:name(可选,str)副本的名字;before(可选,sheet对象)复制到哪个工作表之前;after(可选,sheet对象)复制到哪个工作表之后

sheet1.copy()
sheet1.copy(name='复制表重名命测试', after=sheet1)
sheet1.copy(name='复制表重名命测试2', before=sheet1)

获取工作表对象

有三种不同的方法可以获取表对象:表名、表索引、表序号

sheet1 = workbook.sheets['工资']  # 通过表名获取指定工作表对象
sheet1 = workbook.sheets[0]  # 通过表索引获取指定工作表对象
sheet1 = workbook.sheets(1)  # 通过表需要获取指定工作表对象,注意序号和索引的区别:()根据序号选择,从1开始;[]根据索引选择,从0开始。

工作表属性

有效行used_range.rows和有效列used_range.columns是比较实用的方法,可以方便获取有效数据进行遍历 

print(str(sheet1.name))  # 获取表名
print(sheet1.index)  # 获取当前表的序号(索引加1)
print(sheet1.used_range.rows, sheet1.used_range.columns)  # 获取有效单元格行和列对象


# 获取有效行和有效列
nrow = sheet1.api.UsedRange.Rows.count  # 有效行数,同sheet1.used_range.rows.count,也可通过长度计算len(sheet1.used_range.rows)
ncol = sheet1.api.UsedRange.Columns.count  # 有效列数,同sheet1.used_range.columns.count,,也可通过长度计算len(sheet1.used_range.columns)
print(nrow, ncol)
# 最大行,最大列:结果同有效行和列
print(sheet1.used_range.last_cell.row)
print(sheet1.used_range.last_cell.column)


for i in sheet1.used_range.columns:  # 可通过有效行或列遍历有效数据
    print(i.value)

删除和清除表数据及表格式

sheet1.clear()  # 清除工作表所有内容和格式
sheet1.clear_contents()  # 清除工作表的所有内容但是保留原有格式
sheet1.clear_formats()   # 删除样式但保留文本
sheet1.delete()  # 删除工作表

工作表行高列宽(自动调整)

sheet1.autofit('c')  # 自动调整列宽
sheet1.autofit('r')  # 自动调整行高
sheet1.autofit()  # 自动调整行高列宽,如上可指定axis参数只设置行或列,无参数时同时设置行和列

单元格对象

获取单元格对象

三种不同的获取单元格对象的方法

1、字母表示法
cell = sheet1.range('F1')  # 获取单个单元格对象
more_cells = sheet1.range('B2:F1')  # 获取单元格区域
2、坐标法

一行一列为起始坐标1,1

cell = sheet1.range(2, 3)  # 获取单个单元格对象,第2行3列
more_cell

http://www.kler.cn/a/286976.html

相关文章:

  • 资料03:【TODOS案例】微信小程序开发bilibili
  • 记录一下OpenCV Contrib 编译踩的坑
  • 迈向 “全能管家” 之路:机器人距离终极蜕变还需几步?
  • MongoDB vs Redis:相似与区别
  • Restormer: Efficient Transformer for High-Resolution Image Restoration解读
  • TP4056锂电池充放电芯片教程文章详解·内置驱动电路资源!!!
  • arcgis js api加载4490服务,以basetilelayer方式
  • CAD如何批量输出PDF?介绍了三种方式
  • HTML 实现炫酷选项卡效果
  • 大道至简 以量取胜
  • 第十五章 rust中进行windows系统开发
  • 北京市公共资源交易中心到访隆道调研交流
  • 封装_私有类字段和方法
  • LabVIEW与Python联合图像处理
  • [知识分享]华为铁三角工作法
  • 交换机攻击了解
  • Redis windows 指定端口的方式启动
  • PHP动物收容所管理系统-计算机毕业设计源码94164
  • uniapp video标签无法播放视频
  • 微软CEO谈AI平台范式转移、AI发展趋势及资本市场动态
  • milvus使用milvus migration工具迁移数据
  • 【c++】通过类来玩转赋值操作“延迟赋值”
  • UE5游戏——显示打击怪物的伤害值显示
  • linux 工作中常用的命令
  • 2024.08.25 校招 实习 内推 面经
  • C++基础面试题 | C++中static的作用?什么场景下会使用static?