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

您所在的位置:网站首页 python赋值语句 Python为什么经过赋值语句之后,两个变量仍然不相等

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

2023-05-09 20:07| 来源: 网络整理| 查看: 265

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

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


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3