写入 Excel 文档

OpenPyXL 也提供了一些方法写入数据,这意味着你的程序可以创建和编辑电子 表格文件。利用 Python,创建一个包含几千行数据的电子表格是非常简单的。 

创建并保存 Excel 文档 

调用 openpyxl.Workbook()函数,创建一个新的空 Workbook 对象。在交互式环 境中输入以下代码: 

>>> import openpyxl
>>> wb = openpyxl.Workbook()
>>> wb.sheetnames
['Sheet']
>>> sheet = wb.active
>>> sheet.title
'Sheet'
>>> sheet.title = 'Spam Bacon Eggs Sheet'
>>> wb.sheetnames
['Spam Bacon Eggs Sheet']

工作簿将从一个工作表开始,名为 Sheet。你可以将新的字符串保存在它的 title 属性中,从而改变工作表的名字。 当修改Workbook对象或它的工作表和单元格时,电子表格文件不会保存,除非你调 用 save()工作簿方法。在交互式环境中输入以下代码(让 example.xlsx 处于当前工 作目录): 

>>> import openpyxl 
>>> wb = openpyxl.load_workbook('example.xlsx') 
>>> sheet = wb.get_active_sheet() 
>>> sheet.title = 'Spam Spam Spam' 
>>> wb.save('example_copy.xlsx') 

这里,我们改变了工作表的名称。为了保存变更,我们将文件名作为字符串传递 给save()方法。传入的文件名与最初的文件名不同,例如'example_copy.xlsx',这将变更 保存到电子表格的一份拷贝中。 当你编辑从文件中加载的一个电子表格时,总是应该将新的、编辑过的电子表 格保存到不同的文件名中。这样,如果代码中有缺陷,导致新的保存到文件中数据 不对或讹误,还有最初的电子表格文件可以处理。 
 

创建和删除工作表 

利用 create_sheet() 和 remove_sheet()方法,可以在工作簿中添加或删除工作表。 在交互式环境中输入以下代码: 

>>> import openpyxl
>>> wb = openpyxl.Workbook()
>>> wb.sheetnames
['Sheet']
>>> wb.create_sheet()
<Worksheet "Sheet1">
>>> wb.sheetnames
['Sheet', 'Sheet1']
>>> wb.create_sheet(index=0, title='First Sheet')
<Worksheet "First Sheet">
>>> wb.sheetnames
['First Sheet', 'Sheet', 'Sheet1']
>>> wb.create_sheet(index=2, title='Middle Sheet')
<Worksheet "Middle Sheet">
>>> wb.sheetnames
['First Sheet', 'Sheet', 'Middle Sheet', 'Sheet1']

create_sheet()方法返回一个新的 Worksheet 对象,名为 SheetX,它默认是工作 簿的最后一个工作表。或者,可以利用 index 和 title 关键字参数,指定新工作表的 索引或名称。 继续前面的例子,输入以下代码:

>>> wb.sheetnames
['First Sheet', 'Sheet', 'Middle Sheet', 'Sheet1']
>>> wb.remove(wb['Middle Sheet'])
>>> wb.remove(wb['Sheet1'])
>>> wb.sheetnames
['First Sheet', 'Sheet']

remove()方法接受一个Worksheet 对象作为其参数,而不是工作表名称的字符 串。如果你只知道要删除的工作表的名称,就调用 wb['sheetname'],将它的返 回值传入 remove()。 在工作簿中添加或删除工作表之后,记得调用 save()方法来保存变更。 

将值写入单元格 

将值写入单元格,很像将值写入字典中的键。在交互式环境中输入以下代码: 

>>> import openpyxl
>>> wb = openpyxl.Workbook()
>>> sheet = wb['Sheet']
>>> sheet['A1'] = 'Hello world!'
>>> sheet['A1'].value
'Hello world!'

如果你有单元格坐标的字符串,可以像字典的键一样,将它用于 Worksheet 对 象,指定要写入的单元格。 

猜你喜欢

转载自blog.csdn.net/dongyu1703/article/details/82287883
今日推荐