Python处理Excel文档之openpyxl

****openpyxl简介**** 还是简单一句:顾名思义,openpyxl就是一个处理excel文档的一个python库。


****openpyxl信息**** openpyxl地址传送 openpyxl依赖jdcal以及et_xmlfile依赖库 jdcal地址 et_xmlfile地址


****openpyxl安装****

#pip安装
sudo pip install openpyxl
#源码编译
python setup.py install

对于如何使用pip安装传送pip教程,源码编译安装呢,下载路径已经在上面了 每次编辑到关于安装的好浪费时间,but~~


创建一个工作簿

wb = workbook()

加载已存在excel文件

filePath = "/data/alic/demo.xlsx"
wb = load_workbook(filename=filePath)

选中sheet

# 选择默认的sheet
ws = wb.active

# 通过索引加载sheet index从0开始
ws = wb.worksheets[index]

# 通过sheet名加载 感觉有问题,中文?
ws = wb.get_sheet_by_name()
# 这个没有问题
ws = wb["name"]

创建sheet

#默认插在工作簿末尾
ws = wb.create_sheet() 
# or
# 插入在工作簿的指定位置位置 index从0开始
ws = wb.create_sheet(index) 

更改sheet的名字

# 新建默认的话 sheet0 sheet1 ...
ws.title = "hello"

获取sheet的名称

sheet_name = wb.get_sheet_names()
print sheet_name
# or
for sheet in wb:
    print sheet.title

单元格操作

# 获取一个单元格的value
value = ws['B2']
# or
value = ws.cell('B2')
# or 非常推荐 遍历都很方便
value = ws.cell(row=1,column=2)

#获取多个单元格
cells = ws['A1':'E4']

#为一个单元格赋值
 ws['B2'] = "alic"
# or
ws.cell('B2') = "hello"
# or 非常推荐 遍历都很方便
ws.cell(row=1,column=2) = "value"

# 遍历多个单元格
for row in ws.iter_rows('A1:D2'):
      for cell in row: 
            print cell

获取当前工作表的已有数据的对象

# 所有行
ws.rows

# 所有列
ws.columns

获取当前工作表的数据长度与宽度

row_length = len(ws.rows)
cloumn_length = len(ws.columns)
# 推荐 centOS上面的会报错
row-length = len(list(ws.rows))
cloumn_length = len(list(ws.rows))

保存文件

# 注意要是加载进来的路径与保存的路径一致文件将会被覆盖
wb.save(path)

# 也可以将文件作为模板保存  as_template默认为False
wb.save('document_template.xltx', as_template=True)

简单的样式处理

# 文本对齐方式
align = Alignment(horizontal='center', vertical='center')
ws.cell(row=deng_lu_taskRow, column=index + 3).alignment = align

# 字体大小
font = Font(size=10)
ws.cell(row=taskRow, column=column).font = font

具体样式Click


本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏代码GG之家

android am 命令简单讲解(一)

讲完了 dumpsys ,这节我们看下 am 命令,这个不同于 dumpsys的可执行文件, am 是个脚本文件。 具体来看,先从android.mk来阅读下...

2035
来自专栏守候书阁

vue+webpack搭建单文件应用和多文件应用webpack.config.js的写法区别

这几天,都遇到过有人问过相似的问题,就是用vue和webpack搭建目录的时候,怎么把单页面应用的配置改成多文件应用,或者是怎么把多文件应用的配置改成单文件应用...

683
来自专栏Unity

天天德州-海外版-Unity多语言配置实现

不同类型的文本实现不一样,思路是一致的,首先生成本地配置描述,在运行时脚本根据语言类型读取配置数据。

1043
来自专栏程序员互动联盟

【Windows编程】系列第八篇:创建通用对话框

Windows系统之所以是目前最流行的桌面系统,也是因为Windows有一套标准化,统一友好的交互界面,比如菜单、工具栏、状态栏以及各个控件。当然除了这些单独的...

31114
来自专栏向前进

vue-cli脚手架npm相关文件解读(6)build.js

系列文章传送门: 1、build/webpack.base.conf.js 2、build/webpack.prod.conf.js 3、build/webp...

3938
来自专栏从零开始学自动化测试

python爬虫beautifulsoup4系列3

前言 本篇手把手教大家如何爬取网站上的图片,并保存到本地电脑 一、目标网站 1.随便打开一个风景图的网站:http://699pic.com/sousuo...

33610
来自专栏程序生活

Python爬虫系列(六)外国图库Unsplash图片自动化下载

再做一个网站,要找一些高清图片,然后同学推荐了这个网站:Unsplash 。但是每张图片下载要手动点,然后下拉加载更多图片,效率不高,所以自己写了爬虫程序,进...

4719
来自专栏python学习之旅

Python网络爬虫笔记(三):下载博客园随笔到Word文档

(一)   说明 在上一篇的基础上修改了下,使用lxml提取博客园随笔正文内容,并保存到Word文档中。 操作Word文档会用到下面的模块: pip insta...

3836
来自专栏农夫安全

【笔记】记录Cy牛的任意密码重置姿势

跟第三个有点类似,只判断了接收端和验证码是否一致,未判断接收端是否和用户匹配,因此修改接收端可达到重置目的

1102
来自专栏西二旗一哥

iOS - Add apple document

763

扫码关注云+社区