ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

xlrd写入excel

2020-08-11 08:33:37  阅读:494  来源: 互联网

标签:xlsx sheet wb excel 写入 nrows sheet1 xlrd data


import xlrd
from xlutils.copy import copy

xlsx_path = '/Users/hui/Desktop/test.xlsx'
data = [[i for i in range(10)] for j in range(3)]


def write_date_to_xlsx(xlsx_path, data):

    print(xlsx_path)
    print(data)

    # 1. 打开excel表
    wb = xlrd.open_workbook(xlsx_path)
    sheets = wb.sheet_names()
    print(sheets)

    # 2. 获取指定的sheet
    sheet1 = wb.sheet_by_index(0)
    sheet2 = wb.sheet_by_name('school_sheet')
    print(sheet1, sheet2)

    # 3. sheet对象的属性, 行和列是已经使用的
    name, nrows, ncols = sheet1.name, sheet1.nrows, sheet1.ncols
    print(name, nrows, ncols)

    # 4. 取某一行或者某一列的值
    print(sheet1.row_values(0), sheet1.col_values(0), sheet1.cell_value(0, 0))
    wb = xlrd.open_workbook(xlsx_path)


    # 5. 写入数据
    # 获取目前的行、列情况,必须使用wb对象,获取nrows
    nrows = wb.sheet_by_index(0).nrows

    # 复制副本
    copy_xlsx = copy(wb)

    # 打开sheet,targe_sheet仅用于写入数据
    target_sheet = copy_xlsx.get_sheet(0)

    # 循环逐行写入
    for row_data in data:
        ncols = 0
        for cell_data in row_data:
            target_sheet.write(nrows, ncols, cell_data)
            ncols += 1
        nrows += 1

    # 保存
    copy_xlsx.save(xlsx_path)



if __name__ == '__main__':

    write_date_to_xlsx(xlsx_path, data)


标签:xlsx,sheet,wb,excel,写入,nrows,sheet1,xlrd,data
来源: https://www.cnblogs.com/hui-code/p/13473438.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有