上午发布的问答中,发现数据没有完全被复制,只复制了一行
然后我研究了一下午,发现worksheet[scope].value的值只保存了第一行,其他行全是None。可是明明已经经过赋值语句了,为什么worksheet[scope].value != worksheet_copy["D2:D19"].value?
我的想法是赋值语句没有成功执行,如果是这样的话,为什么会出现这种情况呢?
import xlwings as xw
from openpyxl import Workbook
def number_to_column(number: int) -> str:
"""将数字转换为Excel列号"""
column = ''
while number > 0:
number -= 1
column = chr(number % 26 + ord('A')) + column
number //= 26
return column
L = ['北京市', '天津市', '河北省', '山西省', '内蒙古自治区',
'辽宁省', '吉林省', '黑龙江省',
'上海市', '江苏省', '浙江省', '安徽省', '福建省', '江西省', '山东省',
'河南省', '湖北省', '湖南省', '广东省', '广西壮族自治区', '海南省',
'重庆市', '四川省', '贵州省', '云南省', '西藏自治区',
'陕西省', '甘肃省', '青海省', '宁夏回族自治区', '新疆维吾尔自治区']
wb = Workbook()
ws = wb.create_sheet(title = "总表")
ws['A1'] = "年份"
year = 2004
for j in range(2,20):
cell = 'A{}'.format(j)
ws[cell] = '{}年'.format(year)
year += 1
for i in range(31):
cell = '{}1'.format(number_to_column(i + 2))
ws[cell] = L[i]
default_sheet = wb['Sheet']
wb.remove(default_sheet)
wb.save("2004年至2021年中国各省碳吸收率总表.xlsx")
app = xw.App(visible = False, add_book = False)
file = "2004年至2021年中国各省碳吸收率总表.xlsx"
file_copy = "中国各省碳吸收率.xlsx"
workbook = app.books.open(file)
workbook_copy = app.books.open(file_copy)
worksheet = workbook.sheets["总表"]
for i in range(31):
worksheet_copy = workbook_copy.sheets[L[i]]
scope = "{}2:{}19".format(number_to_column(i + 2), number_to_column(i + 2)) # 数据作用域
worksheet[scope].value = worksheet_copy["D2:D19"].value
print(worksheet[scope].value == worksheet_copy["D2:D19"].value)
##workbook.save()
##workbook.close()