我无法找到使用xlwt写入现有文件的示例。我有一个我需要写的现有xls文件。当我使用xlrd读取文件时,我似乎无法弄清楚如何将返回的“Book”类型转换为xlwt.Workbook。如果有人可以给我一个例子,我将不胜感激。
答案 0 :(得分:247)
这是我最近用来做的一些示例代码。
它打开一个工作簿,向下行,如果满足条件,它会在行中写入一些数据。最后它保存修改后的文件。
from xlutils.copy import copy # http://pypi.python.org/pypi/xlutils
from xlrd import open_workbook # http://pypi.python.org/pypi/xlrd
from xlwt import easyxf # http://pypi.python.org/pypi/xlwt
START_ROW = 297 # 0 based (subtract 1 from excel row number)
col_age_november = 1
col_summer1 = 2
col_fall1 = 3
rb = open_workbook(file_path,formatting_info=True)
r_sheet = rb.sheet_by_index(0) # read only copy to introspect the file
wb = copy(rb) # a writable copy (I can't read values out of this, only write to it)
w_sheet = wb.get_sheet(0) # the sheet to write to within the writable copy
for row_index in range(START_ROW, r_sheet.nrows):
age_nov = r_sheet.cell(row_index, col_age_november).value
if age_nov == 3:
#If 3, then Combo I 3-4 year old for both summer1 and fall1
w_sheet.write(row_index, col_summer1, 'Combo I 3-4 year old')
w_sheet.write(row_index, col_fall1, 'Combo I 3-4 year old')
wb.save(file_path + '.out' + os.path.splitext(file_path)[-1])
答案 1 :(得分:20)
您需要xlutils.copy
。尝试这样的事情:
from xlutils.copy import copy
w = copy('book1.xls')
w.get_sheet(0).write(0,0,"foo")
w.save('book2.xls')
请注意,默认情况下,您无法覆盖this question。
中所述的单元格答案 2 :(得分:6)
代码示例正是如此:
from xlutils.copy import copy
from xlrd import *
w = copy(open_workbook('book1.xls'))
w.get_sheet(0).write(0,0,"foo")
w.save('book2.xls')
你需要创建book1.xls来测试,但你明白了。
答案 3 :(得分:2)
我遇到了同样的问题。我的客户订购了Python 3.4脚本,用于更新XLS(而不是XLSX)Excel文件。
第一个包xlrd是通过“pip install”安装的,我的Python主页没有问题。
第二个xlwt需要说“pip install xlwt-future”才能兼容。
第三个xlutils不支持Python 3,但我对它进行了一点调整,现在它至少适用于虚拟脚本:
#!C:\Python343\python
from xlutils.copy import copy # http://pypi.python.org/pypi/xlutils
from xlrd import open_workbook # http://pypi.python.org/pypi/xlrd
from xlwt import easyxf # http://pypi.python.org/pypi/xlwt
file_path = 'C:\Dev\Test_upd.xls'
rb = open_workbook('C:\Dev\Test.xls',formatting_info=True)
r_sheet = rb.sheet_by_index(0) # read only copy to introspect the file
wb = copy(rb) # a writable copy (I can't read values out of this, only write to it)
w_sheet = wb.get_sheet(0) # the sheet to write to within the writable copy
w_sheet.write(1, 1, 'Value')
wb.save(file_path)
我在此处附上了文件:http://ifolder.su/43507580
如果过期,请写信给alexander.samoylov@gmail.com。
P.S。:在虚拟示例中没有调用某些函数,因此它们也可能需要进行调整。谁想要这样做,请在Google帮助下逐个修复例外情况。这不是一项非常困难的任务,因为包裹代码很小......
答案 4 :(得分:1)
我是openpyxl
# -*- coding: utf-8 -*-
import openpyxl
file = 'sample.xlsx'
wb = openpyxl.load_workbook(filename=file)
# Seleciono la Hoja
ws = wb.get_sheet_by_name('Hoja1')
# Valores a Insertar
ws['A3'] = 42
ws['A4'] = 142
# Escribirmos en el Fichero
wb.save(file)