openpyxl特点

openpyxl(可读写excel表)专门处理Excel2007及以上版本产生的xlsx文件,xls和xlsx之间转换容易 注意:如果文字编码是“gb2312” 读取后就会显示乱码,请先转成Unicode

1、openpyxl 读写单元格时,单元格的坐标位置起始值是(1,1),即下标最小值为1,否则报错!

tableTitle = ['userName', 'Phone', 'age', 'Remark']

# 维护表头

# if row < 1 or column < 1:

# raise ValueError("Row or column values must be at least 1")

# 如上,openpyxl 的首行、首列 是 (1,1)而不是(0,0),如果坐标输入含有小于1的值,提示 :Row or column values must be at least 1,即最小值为1.

for col in range(len(tableTitle)):

c = col + 1

ws.cell(row=1, column=c).value = tableTitle[col]

2、openpyxl 支持直接横纵坐标访问,如A1,B2...

ws['A4'] = 4 #直接赋值

openpyxl操作excel

Excel文件三个对象

workbook: 工作簿,一个excel文件包含多个sheet。

sheet:工作表,一个workbook有多个,表名识别,如“sheet1”,“sheet2”等。

cell: 单元格,存储数据对象

1、新建表

A workbook至少创建一个worksheet.

通过openpyxl.workbook.Workbook.active()得到worksheet

wb = Workbook(encoding='UTF-8')

ws = wb.active

注意:

该方法使用_active_sheet_index属性, 默认会设置0,也就是第一个worksheet。除非手动修改,否则使用active方法得到都是第一个worksheet。

你也可以创建worksheets,通过 openpyxl.workbook.Workbook.create_sheet() 方法:

ws = wb.create_sheet("Mysheet") #插入到最后(default)

#或者

ws = wb.create_sheet("Mysheet", 0) #插入到最开始的位置

创建的sheet的名称会自动创建,按照sheet,sheet1,sheet2自动增长,通过title属性可以修改其名称。

ws.title = "New Title"

ws = wb.create_sheet(title="Pip")

默认的sheet的tab是白色的,可以通过 RRGGBB颜色来修改sheet_properties.tabColor属性从而修改sheet tab按钮的颜色:

ws.sheet_properties.tabColor = "1072BA"

当你设置了sheet的名称,可以将其看成workbook中的一个key。也可以使用openpyxl.workbook.Workbook.get_sheet_by_name() 方法

单元格赋值

#设定单元格的值,三种方式

sheet.cell(row=2,column=5).value=99

sheet.cell(row=3,column=5,value=100)

ws['A4'] = 4 #write

逐行写

ws.append(iterable)

#添加一行到当前sheet的最底部(即逐行追加从第一行开始) iterable必须是list,tuple,dict,range,generator类型的。 1,如果是list,将list从头到尾顺序添加。 2,如果是dict,按照相应的键添加相应的键值。

ws.append([‘This is A1', ‘This is B1', ‘This is C1'])

ws.append({‘A' : ‘This is A1', ‘C' : ‘This is C1'})

ws.append({1 : ‘This is A1', 3 : ‘This is C1'})

2、读表操作

#打开文件:

from openpyxl import load_workbook

excel=load_workbook('E:/test.xlsx')

#获取sheet:

table = excel.get_sheet_by_name('Sheet1') #通过表名获取

#获取行数和列数:

rows=table.max_row #获取行数

cols=table.max_column #获取列数

#获取单元格值:

Data=table.cell(row=row,column=col).value #获取表格内容,是从第一行第一列是从1开始的,注意不要丢掉 .value

#通过名字

ws = wb["frequency"]

#等同于 ws2 = wb.get_sheet_by_name('frequency')

#不知道名字用index

sheet_names = wb.get_sheet_names()

ws = wb.get_sheet_by_name(sheet_names[index])# index为0为第一张表

#或者

ws =wb.active

# 等同于 ws = wb.get_active_sheet() #通过_active_sheet_index设定读取的表,默认0读第一个表

#活动表表名

wb.get_active_sheet().title

单元格使用

c = ws['A4']

d = ws.cell(row = 4, column = 2) #行列读写

逐行读取

#逐行读

ws.iter_rows(range_string=None, row_offset=0, column_offset=0): range-string(string)-单元格的范围:例如('A1:C4') row_offset-添加行 column_offset-添加列

# 返回一个生成器, 注意取值时要用value,例如:

for row in ws.iter_rows('A1:C2'):

for cell in row:

print cell

#读指定行、指定列:

rows=ws.rows#row是可迭代的

columns=ws.columns#column是可迭代的

#打印第n行数据

print rows[n]#不需要用.value

print columns[n]#不需要用.value

显示有多少张表

wb.get_sheet_names()

#显示表名,表行数,表列数

print ws.title

print ws.max_row

print ws.max_column

公式计算formulae

ws["A1"] = "=SUM(1, 1)"

ws["A1"] = "=SUM(B1:C1)"

3、操作实例

#-*-coding:utf-8-*-

# Time:2017/9/21 19:02

# Author:YangYangJun

from openpyxl import Workbook

from openpyxl.reader.excel import load_workbook

import os

import time

def writeExcel():

# 获取文件路径

excelPath = os.path.join(os.getcwd(), 'ExcelData')

print "****"

print excelPath

# 定义文件名称

# invalid mode ('wb') or filename: 'Excel2017-09-21_20:15:57.xlsx' 这种方式明明文件,会提示保存失败,无效的文件名。

# nameTime = time.strftime('%Y-%m-%d_%H:%M:%S')

nameTime = time.strftime('%Y-%m-%d_%H-%M-%S')

excelName = 'Excel' + nameTime + '.xlsx'

ExcelFullName= os.path.join(excelPath,excelName)

print ExcelFullName

wb = Workbook()

ws = wb.active

tableTitle = ['userName', 'Phone', 'age', 'Remark']

# 维护表头

# if row < 1 or column < 1:

# raise ValueError("Row or column values must be at least 1")

# 如上,openpyxl 的首行、首列 是 (1,1)而不是(0,0),如果坐标输入含有小于1的值,提示 :Row or column values must be at least 1,即最小值为1.

for col in range(len(tableTitle)):

c = col + 1

ws.cell(row=1, column=c).value = tableTitle[col]

# 数据表基本信息

tableValues = [['张学友', 15201062100, 18, '测试数据!'], ['李雷', 15201062598, 19, '测试数据!'],['Marry', 15201062191, 28, '测试数据!']]

for row in range(len(tableValues)):

ws.append(tableValues[row])

#wb.save(ExcelFullName)

wb.save(filename=ExcelFullName)

return ExcelFullName

def readExcel(ExcelFullName):

wb = load_workbook(ExcelFullName)

#wb = load_workbook(filename=ExcelFullName)

# 获取当前活跃的worksheet,默认就是第一个worksheet

#ws = wb.active

# 当然也可以使用下面的方法

# 获取所有表格(worksheet)的名字

sheets = wb.get_sheet_names()

print sheets

# # 第一个表格的名称

sheet_first = sheets[0]

# # 获取特定的worksheet

#

ws = wb.get_sheet_by_name(sheet_first)

print "***"

print sheet_first

print ws.title

print "^^^"

# 获取表格所有行和列,两者都是可迭代的

rows = ws.rows

print rows

columns = ws.columns

# 迭代所有的行

for row in rows:

line = [col.value for col in row]

print line

# 通过坐标读取值

print ws['A1'].value # A表示列,1表示行

print ws.cell(row=1, column=1).value

if __name__ == '__main__':

ExcelFullName = writeExcel()

readExcel(ExcelFullName)

# 显示表名,表行数,表列数

print "Work Sheet Titile:", ws.title

print "Work Sheet Rows:", ws.max_row

print "Work Sheet Cols:", ws.max_column

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持爱蒂网。

python openpyxl详解_python openpyxl使用方法详解相关推荐

  1. python读取文件详解_python 文件读取方法详解

    #绝对路径# f =开放(' \/用户\/方\/下载\/我的古诗.文本的模式= ' r ',编码= ' utf - 8\u201D) =() # #内容打印(内容)#()#相对路径f =开放(\u20 ...

  2. python中的class怎么用_对python 中class与变量的使用方法详解

    python中的变量定义是很灵活的,很容易搞混淆,特别是对于class的变量的定义,如何定义使用类里的变量是我们维护代码和保证代码稳定性的关键. #!/usr/bin/python #encoding ...

  3. python中class变量_对python 中class与变量的使用方法详解

    python中的变量定义是很灵活的,很容易搞混淆,特别是对于class的变量的定义,如何定义使用类里的变量是我们维护代码和保证代码稳定性的关键. #!/usr/bin/python #encoding ...

  4. python连接access数据库odbc_对Python通过pypyodbc访问Access数据库的方法详解

    看书上通过ODBC访问数据库的案例,想实践一下在Python 3.6.1中实现access2003数据库的链接,但是在导入odbc模块的时候出现了问题,后来查了一些资料就尝试着使用pypyodbc,最 ...

  5. python修改xml标签的值_对python修改xml文件的节点值方法详解

    这是我的xml文件结构 <?xml version='1.0' encoding='utf-8'?> JPEGImages train_2018-05-08_1000.jpg D:\all ...

  6. python读取大文件csv_对python中大文件的导入与导出方法详解

    1.csv文件的导入和导出 通过一个矩阵导出为csv文件,将csv文件导入为矩阵 将csv文件导入到一个矩阵中 import numpy my_matrix = numpy.loadtxt(open( ...

  7. python字典键盘添加元素_对python字典元素的添加与修改方法详解

    1.字典中的键存在时,可以通过字典名+下标的方式访问字典中改键对应的值,若键不存在则会抛出异常.如果想直接向字典中添加元素可以直接用字典名+下标+值的方式添加字典元素,只写键想后期对键赋值这种方式会抛 ...

  8. python判断输入数字大于0,对python 判断数字是否小于0的方法详解

    对python 判断数字是否小于0的方法详解 为了精度更准确 可以使用数字的绝对值 < 1.0e-16  或者 < 1.0e-8来对比 abs(Num) 以上这篇对python 判断数字是 ...

  9. 站长在线Python精讲:在Python中匹配字符串的3个方法详解

    欢迎你来到站长在线的站长学堂学习Python知识,本文学习的是<在Python中匹配字符串的3个方法详解>.本知识点主要内容有:使用match()方法进行匹配.使用search()方法进行 ...

  10. 站长在线Python精讲:在Python中格式化字符串的两种方法详解

    欢迎你来到站长在线的站长学堂学习Python知识,本文学习的是<在Python中格式化字符串的两种方法详解>.本知识点主要内容有:使用%操作符格式化字符串和使用format()方法格式化字 ...

最新文章

  1. 路由器的转发能力PPS
  2. 基于移位寄存器的序列密码
  3. kubernetes-Deployment
  4. 定制mini2440 wince启动界面
  5. AC_Dream 1216 G - Beautiful People
  6. redis系列之1----redis简介以及linux上的安装
  7. Juniper防火墙新手教程8:Juniper防火墙配置的导入及导出
  8. Java中导入Excel文件
  9. 聊聊并发编程中的10个坑
  10. 微信小程序 基本认识
  11. 数据库日常之修改MySQL数据库密码的方法
  12. WEB在打印fr3报表上显示二维码和图片
  13. selenium最新各浏览器driver驱动下载地址
  14. 当当网 R 语言学习资料统计分析
  15. 视频相识度算法思路文献记录
  16. 【蓝桥杯c++(Python)每日练习】每日刷题day10:小雨妹的游泳时间,小雨妹的平均数
  17. 分享一个超好用的项目进度模板(包括计划进度与实际进度对比甘特图)
  18. 软件版本管理工具大比拼
  19. 【51系列之Proteus仿真】Proteus8.9安装及下载教程
  20. 接口自动化测试三大优势

热门文章

  1. TS在vue2项目中的写法
  2. SpringAOP源码解析总结
  3. 华为云城市峰会这三年,见证城市从“智变”到“质变”
  4. jmeter常见问题3-各种BeanShell处理器的作用以及使用方法
  5. gdt描述_GDT解释
  6. linux如何查看操作系统版本、内核、cup等信息
  7. 为什么deceit显示无服务器,Deceit游戏崩溃解决办法_Deceit游戏进不去怎么办_玩游戏网...
  8. Fastq与Fasta格式
  9. 架构初探-谁动了我的蛋糕
  10. 背景平铺php,CSS_CSS控制背景图像平铺实现边框阴影效果,一款用CSS控制背景图像平铺, - phpStudy...