鱼C论坛

 找回密码
 立即注册
查看: 993|回复: 1

[已解决]求助~~

[复制链接]
发表于 2024-1-31 16:54:22 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
可能我之前的问题没有表达清楚:

1.定义了如下函数:

def exclude_rows_and_cols():

..........

return exclude_rules(sheet)


我首先在循环外调用该函数针对“汇总表.xls"分别按sheet名进行了行/列排除规则录入;

调用该函数后储存的是:{'sheet1': {'排除行': [0, 1], '排除列': [776456368743]}, 'sheet2': {'排除行': [0, 1, 2, 3], '排除列': [1148601586]},'sheet3': {'排除行': [0, 1], '排除列': [776456368743]}, 'sheet4': {'排除行': [0, 1, 2, 3], '排除列': [1148601586]}}这样的结果。


2.然后我怎么样才能(在循环内)取出这个结果和现有sheet名逐一比对,当sheet同名时自动调用相应的行/列排除规则。

意思就是说:默认后续(循环内)所有文件簿的所有sheet都与“汇总表.xls"的sheet一一对应,(在循环内)我只想调用之前已经储存好的排除规则,而不需要再一一录入。



回复请注意python格式


不晓得这次我表达清楚没?可能我自己死循环了,大家别笑话我~~
最佳答案
2024-1-31 16:55:22
不用担心,我明白你的问题了。你想在循环内使用之前存储的排除规则,而不需要再一次录入。解决这个问题的方法是,在循环内部使用字典来检索和应用排除规则。以下是一个示例代码,演示了如何实现这个功能:
def exclude_rows_and_cols():
    # 在这里实现你的排除规则录入逻辑
    exclude_rules = {
        'sheet1': {'排除行': [1, 2], '排除列': [3, 4]},
        'sheet2': {'排除行': [2, 3], '排除列': [1, 2]}
    }
    return exclude_rules

exclude_rules = exclude_rows_and_cols()

# 假设你有一个包含多个文件簿的列表
file_books = ['file_book1.xls', 'file_book2.xls', 'file_book3.xls']

for file_book in file_books:
    # 这里假设你使用的是openpyxl库来处理Excel文件
    # 打开文件簿
    wb = openpyxl.load_workbook(file_book)

    for sheet_name in exclude_rules:
        if sheet_name in wb.sheetnames:
            # 获取当前sheet对象
            sheet = wb[sheet_name]

            # 获取排除规则
            rules = exclude_rules[sheet_name]
            exclude_rows = rules['排除行']
            exclude_cols = rules['排除列']

            # 应用排除规则
            for row_num in exclude_rows:
                sheet.row_dimensions[row_num].hidden = True
            for col_num in exclude_cols:
                sheet.column_dimensions[get_column_letter(col_num)].hidden = True

    # 其他操作,比如保存文件簿
    wb.save(f'new_{file_book}')
    wb.close()

在这个示例代码中,`exclude_rows_and_cols`函数仍然用于录入排除规则,并返回一个字典。在循环内部,我们首先检查当前的sheet是否存在于文件簿中(使用`if sheet_name in wb.sheetnames`)。如果存在,我们可以获取该表格并应用相应的排除规则。通过`sheet.row_dimensions[row_num].hidden = True`和`sheet.column_dimensions[get_column_letter(col_num)].hidden = True`来隐藏行和列。

希望这样的解释对你有所帮助!如果还有其他问题,请随时提问。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-1-31 16:55:22 | 显示全部楼层    本楼为最佳答案   
不用担心,我明白你的问题了。你想在循环内使用之前存储的排除规则,而不需要再一次录入。解决这个问题的方法是,在循环内部使用字典来检索和应用排除规则。以下是一个示例代码,演示了如何实现这个功能:
def exclude_rows_and_cols():
    # 在这里实现你的排除规则录入逻辑
    exclude_rules = {
        'sheet1': {'排除行': [1, 2], '排除列': [3, 4]},
        'sheet2': {'排除行': [2, 3], '排除列': [1, 2]}
    }
    return exclude_rules

exclude_rules = exclude_rows_and_cols()

# 假设你有一个包含多个文件簿的列表
file_books = ['file_book1.xls', 'file_book2.xls', 'file_book3.xls']

for file_book in file_books:
    # 这里假设你使用的是openpyxl库来处理Excel文件
    # 打开文件簿
    wb = openpyxl.load_workbook(file_book)

    for sheet_name in exclude_rules:
        if sheet_name in wb.sheetnames:
            # 获取当前sheet对象
            sheet = wb[sheet_name]

            # 获取排除规则
            rules = exclude_rules[sheet_name]
            exclude_rows = rules['排除行']
            exclude_cols = rules['排除列']

            # 应用排除规则
            for row_num in exclude_rows:
                sheet.row_dimensions[row_num].hidden = True
            for col_num in exclude_cols:
                sheet.column_dimensions[get_column_letter(col_num)].hidden = True

    # 其他操作,比如保存文件簿
    wb.save(f'new_{file_book}')
    wb.close()

在这个示例代码中,`exclude_rows_and_cols`函数仍然用于录入排除规则,并返回一个字典。在循环内部,我们首先检查当前的sheet是否存在于文件簿中(使用`if sheet_name in wb.sheetnames`)。如果存在,我们可以获取该表格并应用相应的排除规则。通过`sheet.row_dimensions[row_num].hidden = True`和`sheet.column_dimensions[get_column_letter(col_num)].hidden = True`来隐藏行和列。

希望这样的解释对你有所帮助!如果还有其他问题,请随时提问。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-23 19:22

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表