Excel:指定列转指定行

功能

将指定的a-b列转到指定的c-d行

示例

将上图转为下图

代码

import openpyxl

def transform_column_to_rows(input_file, output_file, x):
    # 打开原始Excel文件
    wb = openpyxl.load_workbook(input_file)
    sheet = wb.active

    # 打开另一个存储的Excel文件
    new_wb = openpyxl.load_workbook(output_file)
    new_sheet = new_wb.active

    # 获取原始数据的行数
    # max_row = sheet.max_row
    max_row = 287#直接指定

    # 循环遍历原始数据
    for r in range(2, max_row + 1):
        # 获取第r行的值
        city_name = sheet.cell(row=r, column= 1).value
        year = sheet.cell(row=1, column= x).value
        original_value = sheet.cell(row=r, column=x).value

        # 将值写入到新的Excel文件的第5*x行
        new_sheet.cell(row=5 * (r - 1)+  (x - 6), column=3, value=original_value)
        new_sheet.cell(row=5 * (r - 1) + (x - 6), column=2, value=year)
        # new_sheet.cell(row=5 * (r - 1) + (x - 6), column=2, value=2010+x)#不要“年”字
        new_sheet.cell(row=5 * (r - 1) + (x - 6), column=1, value=city_name)

    # 保存新的Excel文件
    new_wb.save(output_file)

# 用法示例:
# 将第2-7列的数据转为第5 * (r - 1) + (x - 6)行并存储到新的Excel文件
for i in range(2,7):
    transform_column_to_rows("data.xlsx", "output.xlsx", i)

  • 6
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值