python的EXCEL脚本

作用

对给定的列提取第1行,第27行,2-24行红色填充的数据,替换并生成sql语句,保存为output.txt

代码

要求安装openpyxl库

python 复制代码
pip intall openpyxl
python 复制代码
import openpyxl
### 对给定的列提取第1行,第27行,2-24行红色填充的数据,替换并生成sql语句,保存为output.txt ###

# 定义颜色填充的识别函数
def is_red_fill(cell):
    # 检查单元格是否有填充,并且填充颜色是否为红色(FFFF0000)
    return cell.fill.start_color.index == 'FFFF0000'

# 读取Excel文件并获取指定列的数据,提取第1行,第27行,2-24行红色填充的数
def get_data_from_excel(file_path, column):
    wb = openpyxl.load_workbook(file_path)
    ws = wb.active
    
    # 获取第1行的文本
    first_row_text = ws[column + '1'].value if ws[column + '1'].value else ''
    
    # 获取第27行的文本
    twenty_seventh_row_text = ws[column + '27'].value if ws[column + '27'].value else ''
    
    # 获取第2行到第24行红色填充的数据
    red_filled_texts = []
    for row in range(2, 25):  # 从第2行到第24行
        cell = ws[column + str(row)]
        if is_red_fill(cell) and cell.value:  # 检查是否有红色填充并且单元格有值
            red_filled_texts.append(cell.value)
    
    return first_row_text, twenty_seventh_row_text, red_filled_texts


# 调用函数并打印结果
def fanction(file_path, columns):  
    result = []
    for column in columns:
        # column = 'AE'  # 假设我们关注的是B列
        first_row_text, twenty_seventh_row_text, red_filled_texts = get_data_from_excel(file_path, column)
        red_filled_texts = tuple(red_filled_texts)
        red_filled_texts = str(red_filled_texts)

        # print(f"第1行的文本: {first_row_text}")
        # print(f"第27行的文本: {twenty_seventh_row_text}")
        # print(f"第2行到第24行红色填充的数据: {red_filled_texts}")

        if (first_row_text == "") | (twenty_seventh_row_text == "") | (len(red_filled_texts) < 3):
            print(column, "数据不全")
            continue  # 数据不全跳过

        sql1 = f"""update t_LIMS_ORDERTASK OT 
left join T_LIMS_TEST t on T.ID=OT.TESTID
set T.TESTUSERNAME='{twenty_seventh_row_text}'
where T.TESTREPORTFORMULA='{first_row_text}' and OT.TESTUSERNAME in {red_filled_texts};"""

        sql2 = f"""update T_LIMS_ORDERTASKLOG L 
left join T_LIMS_ORDERTASK L on L.ORDERTASKID =OT.ID
left join T_LIMS_TEST t on T.ID=OT.TESTID 
set L.CREATEDBYNAME ='{twenty_seventh_row_text}'
where T.TESTREPORTFORMULA='{first_row_text}' and L.CREATEDBYNAME  in {red_filled_texts} and L.OPERATIONTYPE ='班长审核';"""

        result.append(sql1)
        result.append(sql2)

    with open('output.txt', 'w', encoding='utf-8') as f:
        for item in result:
            f.write("%s\n\n" % item)
        print("output.txt保存成功!")

path = r"C:\Users\16071\Desktop\LIMS未持证上岗资质异常处理.xlsx"
cols = ['B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'AA', 'AE']
fanction(path, cols)
相关推荐
bzmK1DTbd6 小时前
Git版本控制:Java项目中的分支管理与合并策略
java·开发语言·git
Rust研习社6 小时前
为什么 Rust 没有空指针?
开发语言·后端·rust
landyjzlai6 小时前
蓝迪哥玩转Ai(8)---端侧AI:RK3588 端侧大语言模型(LLM)开发实战指南
人工智能·python
kyriewen116 小时前
WebAssembly:前端界的“外挂”,让C++代码在浏览器里跑起来
开发语言·前端·javascript·c++·单元测试·ecmascript
我叫黑大帅8 小时前
如何通过 Python 实现招聘平台自动投递
后端·python·面试
其实防守也摸鱼8 小时前
CTF密码学综合教学指南--第九章
开发语言·网络·python·安全·网络安全·密码学·ctf
砚底藏山河8 小时前
Python量化开发:2026最佳实时股票数据API接口推荐与对比
开发语言·windows·python
AlunYegeer9 小时前
JAVA,以后端的视角理解前端。在全栈的路上迈出第一步。
java·开发语言·前端
研究点啥好呢9 小时前
专为求职者开发的“面馆”!!!摆脱面试焦虑!!!
python·面试·开源·reactjs·求职招聘·fastapi
VBAMatrix9 小时前
deepseek-v4正式接入Excel,一键生成财务分析报告
word·excel·审计·财务分析·deepseek·会计师事务所·tb工具箱