我想读取xlsx文件,将所有小于0.0001的值更改为0.01。我可以读取值并打印它们,但我无法更改它们?
import pylab
from openpyxl import load_workbook
wb = load_workbook(filename = 'TF-Automation.xlsx', use_iterators=True)
ws = wb.get_sheet_by_name(name = 'Huvudmatris')
for row in ws.iter_rows():
for cell in row:
if cell.internal_value < 0.00001:
cell.set_value = 0.000001
print cell.internal_value
答案 0 :(得分:1)
来自文档:http://pythonhosted.org/openpyxl/api.html
openpyxl.reader.excel.load_workbook(filename,use_iterators=False)[source] :
Open the given filename and return the workbook Parameters: filename (string) – the path to open use_iterators (bool) – use lazy load for cells Return type: openpyxl.workbook.Workbook
使用延迟加载时,所有工作表都将是
openpyxl.reader.iter_worksheet.IterableWorksheet
和返回 工作簿将是只读的。
不要使用use_iterators=True
。另外,如果您想使用新值更新xlsx,则需要致电.save(filename)
。