哈夫曼树_ 2023-05-09 18:48 采纳率: 57.7%
浏览 25
已结题

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






    


  • 写回答

1条回答 默认 最新

  • 哈夫曼树_ 2023-05-09 20:48
    关注

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

    img


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

    评论

报告相同问题?

问题事件

  • 系统已结题 5月17日
  • 修改了问题 5月9日
  • 创建了问题 5月9日

悬赏问题

  • ¥15 preLaunchTask"C/C++: aarch64- apple-darwin22-g++-14 生成活动 文件”已终止,退出代码为-1。
  • ¥18 关于#贝叶斯概率#的问题:这篇文章中利用em算法求出了对数似然值作为概率表参数,然后进行概率表计算,这个概率表是怎样计算的呀
  • ¥20 C#上传XML格式数据
  • ¥15 elementui上传结合oss接口断点续传,现在只差停止上传和继续上传,各大精英看下
  • ¥100 单片机hardfaulr
  • ¥20 手机截图相片分辨率降低一半
  • ¥50 求一段sql语句,遇到小难题了,可以50米解决
  • ¥15 速求,对多种商品的购买力优化问题(用遗传算法、枚举法、粒子群算法、模拟退火算法等方法求解)
  • ¥100 速求!商品购买力最优化问题(用遗传算法求解,给出python代码)
  • ¥15 虚拟机检测,可以是封装好的DLL,可付费