Python为什么经过赋值语句之后,两个变量仍然不相等

上午发布的问答中,发现数据没有完全被复制,只复制了一行

img

img

img

然后我研究了一下午,发现worksheet[scope].value的值只保存了第一行,其他行全是None。可是明明已经经过赋值语句了,为什么worksheet[scope].value != worksheet_copy["D2:D19"].value?

img

img

img


我的想法是赋值语句没有成功执行,如果是这样的话,为什么会出现这种情况呢?

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()






    


数据复制的问题最后我换了一种方法解决,就是放弃一列一列的复制,而是一格一格的复制

img


但是我很是疑惑,为什么之前的代码经过赋值语句之后,两个变量不相等