From 4d0b65555e2d4538866c809cc723aec2c1f6c29f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=A4=A7=E5=B8=88?= Date: Tue, 9 Jun 2026 04:58:03 +0800 Subject: [PATCH] =?UTF-8?q?fix:=20=E5=85=AC=E5=BC=8F-=E9=A2=84=E8=AD=A6?= =?UTF-8?q?=E6=98=8E=E7=BB=86=20A10=E6=96=87=E5=AD=97=E9=98=BB=E6=8C=A1?= =?UTF-8?q?=E6=BA=A2=E5=87=BA=20=E2=80=94=20=E5=88=A0=E9=99=A4=E6=8F=90?= =?UTF-8?q?=E7=A4=BA=E8=A1=8C+=E5=8F=8C=E9=87=8D=E8=BF=87=E6=BB=A4?= =?UTF-8?q?=E6=8E=92=E9=99=A4=E7=A9=BA=E5=80=BC=E8=A1=8C?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/gen_workbook.py | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/src/gen_workbook.py b/src/gen_workbook.py index 6293b38..2ed6b72 100644 --- a/src/gen_workbook.py +++ b/src/gen_workbook.py @@ -192,18 +192,17 @@ for ri,(lab,fm,note) in enumerate(rows8): s8.cell(r,3,note).font=GRAY_F; s8.cell(r,3).border=BORDER for w,c in zip([18,10,35],'ABC'): s8.column_dimensions[c].width=w -# ── S9: 公式-预警明细 ── FILTER 动态筛选(无合并单元格 ≠ #SPILL!) +# ── S9: 公式-预警明细 ── FILTER 动态筛选(A10无内容=溢出通畅) s9=wb.create_sheet('公式-预警明细') s9.cell(1,1,'OA预警明细(FILTER动态筛选·无合并单元格)').font=TITLE_F; s9.cell(1,1).border=GOLD_BD -s9.cell(2,1,'FILTER(有效≥2026!A3:AD200,有效≥2026!AD3:AD200<>"none","无预警")').font=GRAY_F -s9.cell(4,1,f'=FILTER({REF}!A3:AD200,{REF}!AD3:AD200<>"none","🎉 无预警项")').font=FORMULA_F; s9.cell(4,1).border=BORDER -# 给A~AD列设最小宽度,确保溢出结果可见(无合并单元格阻挡) +s9.cell(2,1,'FILTER(有效≥2026!A3:AD200,(有效≥2026!AD3:AD200<>"none")*(有效≥2026!AD3:AD200<>""),"无预警")').font=GRAY_F +# 条件双重过滤:排除 "none" + 排除空值,避免空值行也被选入导致溢出触达A10 +s9.cell(4,1,f'=FILTER({REF}!A3:AD200,({REF}!AD3:AD200<>"none")*({REF}!AD3:AD200<>""),"🎉 无预警项")').font=FORMULA_F; s9.cell(4,1).border=BORDER for i in range(1,31): s9.column_dimensions[get_column_letter(i)].width = 4 if i>1 else 6 s9.column_dimensions['C'].width=22; s9.column_dimensions['D'].width=40 s9.column_dimensions['E'].width=35; s9.column_dimensions['K'].width=12 s9.column_dimensions['AD'].width=10 -s9.cell(10,1,'💡 若WPS显示@前缀,选中单元格→删除@即可正常溢出;若仍#SPILL!→用静态表S14').font=GRAY_F; s9.cell(10,1).fill=INFO_BG # ── S10: 公式-认定分类 ── s10=wb.create_sheet('公式-认定分类')