python-读写Excel:openpyxl-(4)下拉选项设置

使用openpyxl库的DataValidation对象方法可添加下拉选择列表。

DataValidation参数说明:

  1. type: 数据类型("whole", "decimal", "list", "date", "time", "textLength", "custom")
  2. promptTitle :选定单元格后显示提示信息的标题
  3. prompt :选定单元格后显示提示信息的内容
  4. showDropDown 显示下拉箭头,默认False为显示
  5. allow_blank 允许空白,默认为False
  6. showInputMessage 输入内容后是否显示匹配的内容,默认为False
  7. showErrorMessage 不符合输入条件时报错提示信息显示,默认为False

DataValidation可接收两个公式参数formula1 和formula12 ,根据不同的type添加一个或两个公式参数,如果type类型只接收一个公式时,则取formula1为公式。

接收两个公式参数时,可选择operator参数,参数可选值有:"between", "notBetween", "equal", "notEqual", "lessThan", "lessThanOrEqual", "greaterThan", "greaterThanOrEqual"。

参数与Excel关系:

代码演示:

python 复制代码
from openpyxl import Workbook
from openpyxl.worksheet.datavalidation import DataValidation

# 创建一个新的工作簿
wb = Workbook()
ws = wb.create_sheet('666', index=0)

# 设置下拉列表的选项
options = ["张三", "李四", "王五"]

# 创建数据验证对象
dv = DataValidation(type="list", formula1='"{}"'.format(','.join(options)),
                    prompt='选择与选项匹配的内容',
                    promptTitle='请选择姓名',
                    allow_blank=True,
                    showErrorMessage=True,
                    showInputMessage=True, showDropDown=False)

# showInputMessage 输入时模糊首先展示匹配的数据供选择
# showErrorMessage 输入后校验输入的数据是够在选择项当中,不在时给出错误提示,错误提示信息如下:
dv.errorTitle = "无效的选择"
dv.errorStyle = 'warning'  # 错误警告的样式,默认为stop,("stop", "warning", "information")
dv.error = "请选择或输入与下拉数据匹配的数据!"

ws.add_data_validation(dv)  # 将数据验证规则添加到工作表中
# 将数据验证应用于A2:A100单元格区域
dv.add("A2:A100")

# 将数据验证添加到工作表
ws.add_data_validation(dv)

# 保存Excel文件
wb.save(rf'C:\Users\Administrator\Desktop\test001.xlsx')

补充小知识:可手动在条件筛选中设置每个下拉选择的样式

相关推荐
Csvn6 小时前
OpenSpec 详细使用教程
前端
风吹夏回6 小时前
Python 全局异常处理:从“满屏 try-except”到优雅兜底
开发语言·python
小熊Coding7 小时前
Python爬取当当网二手图书项目实战!
开发语言·爬虫·python·beautifulsoup·requests·二手图书
之歆7 小时前
Day19_LESS 完全指南——从入门到工程实践
前端·css·less
秋97 小时前
Java项目运行5天左右自动宕机:系统性定位与解决方案
java·开发语言·python
小江的记录本7 小时前
【JVM虚拟机】垃圾回收GC:垃圾收集器:CMS:核心原理、回收流程、优缺点、废弃原因(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·spring·面试·maven
云水一下7 小时前
HTML5 从入门到精通:实战收官——从零搭建完整静态网站,综合运用所有知识
前端·html5
不总是8 小时前
Windows 系统 Node.js 免安装版(zip)安装与配置教程(2026 最新)
前端·windows·node.js
田里的水稻8 小时前
OE_ubuntu26.04与宿主机之间复制粘贴内容
人工智能·python·机器人
冬奇Lab8 小时前
每日一个开源项目(第105篇):Twenty - 跳出 Salesforce 的圈套,定义现代开源 CRM
前端·后端·开源