会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132493个问题
Python 全系列/ 第十四阶段:自动化操作办公软件、邮件、定时任务等/自动化操作办公软件、邮件、定时任务等 91楼
Python 全系列/ 第十四阶段:自动化操作办公软件、邮件、定时任务等/自动化操作办公软件、邮件、定时任务等 92楼
Python 全系列/ 第十四阶段:自动化操作办公软件、邮件、定时任务等/自动化操作办公软件、邮件、定时任务等 94楼
Python 全系列/ 第十四阶段:自动化操作办公软件、邮件、定时任务等/自动化操作办公软件、邮件、定时任务等 95楼
Python 全系列/ 第十四阶段:自动化操作办公软件、邮件、定时任务等/自动化操作办公软件、邮件、定时任务等 96楼

760911a502871d09402e1adb2ca353f.png

老师我这个问题怎么解决

Python 全系列/ 第十四阶段:自动化操作办公软件、邮件、定时任务等/自动化操作办公软件、邮件、定时任务等 97楼
Python 全系列/ 第十四阶段:自动化操作办公软件、邮件、定时任务等/自动化操作办公软件、邮件、定时任务等 99楼

import xlrd
from xlutils.copy import copy

# 获取数据的方法
def get_data():
    # 读取数据
    wb = xlrd.open_workbook("./base_data/data01.xlsx")
    # 获取sheet
    sh = wb.sheet_by_index(0)
    '''
    {
        a:[{},{},{}],
        b:[{},{},{}],
        c:[{},{},{}],
    }
    '''
    all_data = {}

    for r in range(sh.nrows):   # 遍历每一行
        d = {'type':sh.cell_value(r,1),'name':sh.cell_value(r,2),'count':sh.cell_value(r,3),'price':sh.cell_value(r,4)}
        key = sh.cell_value(r,0)
        if all_data.get(key):   # 如果里面有值 
            all_data[key].append(d)
        else:
            all_data[key] = [d] # 如果没有值
    return all_data

def save(data):
    wb = xlrd.open_workbook('./base_data/data01.xlsx')
    wb2 = copy(wb)
    for key in data.keys():
        ts = wb2.add_sheet(key)
        for i,d in enumerate(data.get(key)):
            ts.write(i,0,d.get('type'))
            ts.write(i,1,d.get('name'))
            ts.write(i,2,d.get('count'))
            ts.write(i,3,d.get('price'))
    wb2.save('./create_data/表格拆分.xlsx')

if __name__ == '__main__':
    all_data = get_data()
    save(all_data)
    # print(all_data)

老师,没办法打开excel xlsx文件,怎么解决20.5-2.PNG


Python 全系列/ 第十四阶段:自动化操作办公软件、邮件、定时任务等/自动化操作办公软件、邮件、定时任务等 100楼

老师,帮忙看下我这段代码,怎么修改成读取某一列的第三行到第十行的数据啊

from openpyxl import load_workbook
from openpyxl import Workbook
import glob


all_works_names = glob.glob('d:/wenjian/4月物料.xlsx')# 读取  Excel 文件

works_names = []# 定义一个空列表存放所有的工单编号


work_name_achievements = []# 定义一个空列表存放所有的工单编号和工单标题

for work_name in all_works_names:# 遍历所有的工单
    if '~' not in work_name:# 排除每一个工单名称里面包含 '~' 的文件名称
        load_works = load_workbook(work_name)# 读取每一个工单
        work_name_achievements.append([load_works['工单']['B3':'B54'].value,load_works['工单']['C3':'C54'].value])# 取出每一个表里面的工单编号和绩效并存入变量为 `work_name_achievements` 的列表

new_book = Workbook()# 使用 openpyxl 创建表格对象

# 新建一个新的 Sheet 名称为 '所有工单物料'
# new_book['Sheet'].title = '所有工单物料'
new_sheet = new_book.create_sheet('所有工单物料',0)
# 定义行号
current_row_num = 1
# 定义姓名列号
name_col = 1
# 定义绩效行号
achievements_col = 2
# 分别定义工单编号和工单标题字段名称
new_book['所有工单物料'].cell(current_row_num, name_col, '工单编号')
new_book['所有工单物料'].cell(current_row_num, achievements_col, '工单标题')
# 每添加进来一组数据行号自增1
current_row_num += 1
# 遍历所有的绩效表名称
for work_name in all_works_names:
    # 排除每一个绩效表名称里面包含 '~' 的文件名称
    if '~' not in work_name:
        # 读取每一个绩效表
        load_work = load_workbook(work_name)
        # 取出每一个表里面的工单编号和工单标题并存入 Sheet 名称为 '所有工单物料' 的工作簿内
        new_book['所有工单物料'].cell(current_row_num, name_col, load_work['工单']['B3'].value)
        new_book['所有工单物料'].cell(current_row_num, achievements_col, load_work['工单']['C3'].value)
        # 每添加进来一组数据行号自增1
        current_row_num += 1

# 将写入的数据保存名称为 '所有工单物料.xlsx' 的 Excel 文件
new_book.save('d:/wenjian/所有工单物料.xlsx')


Python 全系列/ 第十四阶段:自动化操作办公软件、邮件、定时任务等/自动化操作办公软件、邮件、定时任务等 101楼
Python 全系列/ 第十四阶段:自动化操作办公软件、邮件、定时任务等/自动化操作办公软件、邮件、定时任务等 103楼
Python 全系列/ 第十四阶段:自动化操作办公软件、邮件、定时任务等/自动化操作办公软件、邮件、定时任务等 105楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637