标签:注意 active 目录 http install table amp 需要 分配
Openpyxl is a Python library for reading and writing Excel 2010 xlsx/xlsm/xltx/xltm files.
|
1
|
$ pip install openpyxl |
|
1
2
3
4
5
6
7
8
9
10
11
12
13
|
from openpyxl import Workbookwb = Workbook()# 激活 worksheetws = wb.active# 数据可以直接分配到单元格中ws[‘A1‘] = 42# 可以附加行,从第一列开始附加ws.append([1, 2, 3])# Python 类型会被自动转换import datetimews[‘A3‘] = datetime.datetime.now().strftime("%Y-%m-%d")# 保存文件wb.save("sample.xlsx") |
打开查看Excel如下:

There is no need to create a file on the filesystem to get started with openpyxl. Just import the Workbook class and start using it.
|
1
2
|
from openpyxl import Workbookwb = Workbook() |
A workbook至少创建一个worksheet.
通过openpyxl.workbook.Workbook.active()得到worksheet.ws = wb.active
注意:
该方法使用_active_sheet_index属性, 默认会设置0,也就是第一个worksheet。除非手动修改,否则使用active方法得到都是第一个worksheet。
你也可以创建worksheets,通过 openpyxl.workbook.Workbook.create_sheet() 方法:
|
1
2
3
|
>>> ws1 = wb.create_sheet("Mysheet") #插入到最后(default)#或者>>> ws2 = wb.create_sheet("Mysheet", 0) #插入到最开始的位置 |
创建的sheet的名称会自动创建,按照sheet,sheet1,sheet2自动增长,通过title属性可以修改其名称。ws.title = "New Title"
默认的sheet的tab是白色的,可以通过 RRGGBB颜色来修改sheet_properties.tabColor属性从而修改sheet tab按钮的颜色:ws.sheet_properties.tabColor = "1072BA"
当你设置了sheet的名称,可以将其看成workbook中的一个key。也可以使用openpyxl.workbook.Workbook.get_sheet_by_name() 方法
|
1
2
3
4
|
>>> ws3 = wb["New Title"]>>> ws4 = wb.get_sheet_by_name("New Title")>>> ws is ws3 is ws4True |
查看workbook中的所有worksheets名称:openpyxl.workbook.Workbook.get_sheet_names()
|
1
2
|
>>> print(wb.sheetnames)[‘Sheet2‘, ‘New Title‘, ‘Sheet1‘] |
遍历worksheets:
|
1
2
|
>>> for sheet in wb:... print(sheet.title) |
单元格可以看作是worksheet的key,通过key去访问单元格中的数据
|
1
|
>>> c = ws[‘A4‘] |
直接返回A4单元格,如果不存在则会自动创建一个。
|
1
|
>>> ws[‘A4‘] = 4 #直接赋值 |
使用openpyxl.worksheet.Worksheet.cell()方法操作某行某列的某个值:
|
1
|
>>> d = ws.cell(row=4, column=2, value=10) |
注意:
|
1
2
3
|
>>> for i in range(1,101):... for j in range(1,101):... ws.cell(row=i, column=j) |
通过切片Ranges指定许多cells
|
1
|
>>> cell_range = ws[‘A1‘:‘C2‘] |
同样也可以Ranges rows 或者columns :
|
1
2
3
4
|
>>> colC = ws[‘C‘]>>> col_range = ws[‘C:D‘]>>> row10 = ws[10]>>> row_range = ws[5:10] |
也可以使用 openpyxl.worksheet.Worksheet.iter_rows() 方法:(需要指定行->行,截止列)
|
1
2
3
4
5
6
7
8
9
|
>>> for row in ws.iter_rows(min_row=1, max_col=3, max_row=2):... for cell in row:... print(cell)<Cell Sheet1.A1><Cell Sheet1.B1><Cell Sheet1.C1><Cell Sheet1.A2><Cell Sheet1.B2><Cell Sheet1.C2> |
openpyxl.worksheet.Worksheet.iter_cols() 方法:(需要指定列->列,截止行)|
1
2
3
4
5
6
7
8
9
|
>>> for row in ws.iter_rows(min_row=1, max_col=3, max_row=2):... for cell in row:... print(cell)<Cell Sheet1.A1><Cell Sheet1.B1><Cell Sheet1.C1><Cell Sheet1.A2><Cell Sheet1.B2><Cell Sheet1.C2> |
如果你需要遍历所有文件的行或列,可以使用openpyxl.worksheet.Worksheet.rows() 属性:
|
1
2
3
4
5
6
7
8
9
10
11
12
|
>>> ws = wb.active>>> ws[‘C9‘] = ‘hello world‘>>> tuple(ws.rows)((<Cell Sheet.A1>, <Cell Sheet.B1>, <Cell Sheet.C1>),(<Cell Sheet.A2>, <Cell Sheet.B2>, <Cell Sheet.C2>),(<Cell Sheet.A3>, <Cell Sheet.B3>, <Cell Sheet.C3>),(<Cell Sheet.A4>, <Cell Sheet.B4>, <Cell Sheet.C4>),(<Cell Sheet.A5>, <Cell Sheet.B5>, <Cell Sheet.C5>),(<Cell Sheet.A6>, <Cell Sheet.B6>, <Cell Sheet.C6>),(<Cell Sheet.A7>, <Cell Sheet.B7>, <Cell Sheet.C7>),(<Cell Sheet.A8>, <Cell Sheet.B8>, <Cell Sheet.C8>),(<Cell Sheet.A9>, <Cell Sheet.B9>, <Cell Sheet.C9>)) |
或者 openpyxl.worksheet.Worksheet.columns() 属性:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
>>> tuple(ws.columns)((<Cell Sheet.A1>,<Cell Sheet.A2>,<Cell Sheet.A3>,<Cell Sheet.A4>,<Cell Sheet.A5>,<Cell Sheet.A6>,...<Cell Sheet.B7>,<Cell Sheet.B8>,<Cell Sheet.B9>),(<Cell Sheet.C1>,<Cell Sheet.C2>,<Cell Sheet.C3>,<Cell Sheet.C4>,<Cell Sheet.C5>,<Cell Sheet.C6>,<Cell Sheet.C7>,<Cell Sheet.C8>,<Cell Sheet.C9>)) |
最简单最安全的方法保存workbook是使用openpyxl.workbook.Workbook对象的 openpyxl.workbook.Workbook.save()方法:
|
1
2
|
>>> wb = Workbook()>>> wb.save(‘balances.xlsx‘) |
保存的默认位置在python的根目录下。
注意:会自动覆盖已经存在文件名的文件。
像写一样我们可以导入openpyxl.load_workbook()已经存在的workbook:
|
1
2
3
4
|
>>> from openpyxl import load_workbook>>> wb2 = load_workbook(‘test.xlsx‘)>>> print wb2.get_sheet_names()[‘Sheet2‘, ‘New Title‘, ‘Sheet1‘] |
http://openpyxl.readthedocs.io/en/default/usage.html
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
#!/usr/bin/env python# -*- coding: utf-8 -*-from openpyxl import Workbookwb = Workbook()# 激活 worksheetws = wb.active# 数据可以直接分配到单元格中ws[‘A1‘] = 42# 可以附加行,从第一列开始附加ws.append([1, 2, 3])# Python 类型会被自动转换import datetimews[‘A3‘] = datetime.datetime.now().strftime("%Y-%m-%d")# 保存文件wb.save("sample.xlsx") |
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
#!/usr/bin/env python# -*- coding: utf-8 -*-"""http://openpyxl.readthedocs.io/en/default/usage.html"""# workbook相关from openpyxl import Workbookfrom openpyxl.compat import rangefrom openpyxl.utils import get_column_letterwb = Workbook()dest_filename = ‘empty_book.xlsx‘ws1 = wb.activews1.title = "range names"for row in range(1, 40): ws1.append(range(600))ws2 = wb.create_sheet(title="Pi")ws2[‘F5‘] = 3.14ws3 = wb.create_sheet(title="Data")for row in range(10, 20): for col in range(27, 54): _ = ws3.cell(column=col, row=row, value="{0}".format(get_column_letter(col)))print(ws3[‘AA10‘].value)wb.save(filename=dest_filename) |

#!/usr/bin/env python
# -*- coding: utf-8 -*-
from openpyxl.reader.excel import load_workbook
import json
# 读取excel2007文件
wb = load_workbook(filename=r‘test_book.xlsx‘)
# 显示有多少张表
print "Worksheet range(s):", wb.get_named_ranges()
print "Worksheet name(s):", wb.get_sheet_names()
# 取第一张表
sheetnames = wb.get_sheet_names()
ws = wb.get_sheet_by_name(sheetnames[0])
# 显示表名,表行数,表列数
print "Work Sheet Titile:", ws.title
print "Work Sheet Rows:", ws.max_row
print "Work Sheet Cols:", ws.max_column
# 建立存储数据的字典
data_dic = {}
# 把数据存到字典中
for rx in range(1, ws.max_row + 1):
temp_list = []
pid = rx
w1 = ws.cell(row=rx, column=1).value
w2 = ws.cell(row=rx, column=2).value
w3 = ws.cell(row=rx, column=3).value
w4 = ws.cell(row=rx, column=4).value
temp_list = [w1, w2, w3, w4]
data_dic[pid] = temp_list
# 打印字典数据个数
print ‘Total:%d‘ % len(data_dic)
print json.dumps(data_dic, encoding="UTF-8", ensure_ascii=False)
读取结果:
|
1
2
3
4
5
6
7
|
Worksheet range(s): []Worksheet name(s): [u‘\u6d3b\u52a8\u8868‘, u‘\u7528\u6237\u4fe1\u606f‘, u‘Sheet3‘]Work Sheet Titile: 活动表Work Sheet Rows: 3Work Sheet Cols: 5Total:3{"1": ["张三", 18, "男", "广州"], "2": ["李四", 20, "女", "湖北"], "3": ["王五", 25, "女", "北京"]} |
|
1
2
3
4
5
6
|
>>> from openpyxl import Workbook>>> wb = Workbook()>>> ws = wb.active>>> # add a simple formula>>> ws["A1"] = "=SUM(1, 1)">>> wb.save("formula.xlsx") |
标签:注意 active 目录 http install table amp 需要 分配
原文地址:http://www.cnblogs.com/zhaoyingjie/p/6555434.html