首页 > 编程问答 >如何使用 openpyxl 复制单个单元格的条件格式?

如何使用 openpyxl 复制单个单元格的条件格式?

时间:2024-07-26 06:18:21浏览次数:5  
标签:python openpyxl

我正在尝试使用 python 的 openpyxl 将一组 Excel 单元格移动到工作簿中的另一个位置,并偏移一些列。 源工作表有一些使用条件格式的单元格。

好消息是, move_range 完成了大部分工作。 但我一生都无法弄清楚如何复制/移动条件格式;它只是完全迷失了。

有人有想法吗? 谢谢你, /YGA


很不幸, openpyxl 没有提供复制单个单元格条件格式的直接方法。 move_range 方法主要用于移动单元格内容和样式,但它并不总是能正确地处理条件格式,尤其是在涉及到偏移和不同目标区域的情况下。

不过,你可以尝试以下两种方法来实现你的目标:

方法一:使用 copy() 方法和循环

这种方法需要你遍历源单元格范围,并将每个单元格的条件格式复制到目标单元格。

from copy import copy

from openpyxl import load_workbook

# 加载工作簿
wb = load_workbook("your_file.xlsx")
ws = wb["Sheet1"]

# 定义源和目标区域
source_range = ws["A1:A10"] 
target_range = ws["B1:B10"]  

# 遍历单元格并复制条件格式
for source_row, target_row in zip(source_range, target_range):
    for source_cell, target_cell in zip(source_row, target_row):
        # 复制条件格式
        target_cell.conditional_formatting = copy(source_cell.conditional_formatting)

# 保存工作簿
wb.save("your_file.xlsx") 

方法二:使用 conditional_formatting 属性

这种方法需要你直接访问和操作单元格的 conditional_formatting 属性。

from openpyxl import load_workbook

# 加载工作簿
wb = load_workbook("your_file.xlsx")
ws = wb["Sheet1"]

# 获取源单元格的条件格式
source_cell = ws["A1"]
cf = source_cell.conditional_formatting

# 将条件格式应用于目标单元格
target_cell = ws["B1"]
target_cell.conditional_formatting = cf

# 保存工作簿
wb.save("your_file.xlsx") 

需要注意的是,这两种方法都需要你根据实际情况修改代码,例如调整单元格范围、偏移量等。

希望这些信息能帮到你!

标签:python,openpyxl
From: 78795597

相关文章

  • 84 我正在使用 Python 开发 selenium 自动化项目。我收到错误 .NoSuchElementExceptio
    场景是这样的,我将打开一个网页,在使用selenium单击该网页后,它会要求位置访问权限,屏幕上会出现一堆按钮,我正在尝试定位其中一个按钮,但即使正确给出了Xpath地址,我得到.NoSuchElementException:错误能够单击目标按钮你正在使用Selenium在Python中开发自动化项目,并遇到......
  • 在Python 3中删除两个指定字符串之间的字符串
    我正在从事一个NLP项目,该项目要求我从一段文本中删除计算机代码。代码包含在标签<pre><code>和</code></pre>之间。现在我可以做一个简单的正则表达式匹配,但我想概括这个函数,以便它可以删除任何两个指定字符串之间的文本,即使它们是嵌套的。例如,如果我有一个......
  • Azure Open AI - Python 和 Java API 之间 gpt4o 的结果截然不同
    我使用Java和PythonAPI对AzureOpenAI进行相同的调用,但收到截然不同的结果:相同的系统提示相同的用户提示适用于Java和Python的azureai包的相同(最新)版本尽管输入的用户和系统提示完全相同,但响应却非常不同-python提示是“正确的”并......
  • leetcode 输出错误? (Python)
    我的VSCode/本地终端给出了[1,4,1,5,1,6]的正确输出,但不知何故leetcode给了我完全不同的输出。我在这里错过了什么吗?这怎么可能?顺便说一下,这是wigglesort2将我的本地代码复制粘贴到leetcode中给出了不同的输出数组很难在没有看到你的代码的情况下......
  • 当 python 窗口的一部分不在屏幕上时,如何让它自己被记录?
    在Windows10中,大多数应用程序窗口都可以使用OBS等程序进行记录。当窗口被拖动以致其部分内容在显示屏上不可见时,通常OBS仍会接收窗口的内容,即使它在屏幕上不可见。但是,在编写python应用程序时,这似乎不以相同的方式工作。我尝试了几种不同的类似GUI的模块......
  • 使用 aws cdk 设置用户池客户端属性以具有读/写访问权限 - Python
    我试图根据属性给予一些自定义属性特定的读/写访问权限。我收到此错误。资源处理程序返回消息:“无效写入创建客户端时指定的属性(服务:CognitoIdentityProvider,状态代码:400,请求ID:<request_id>)”(RequestToken:<request_token>,HandlerErrorCode:InvalidRequest)任何人都可以为......
  • 试图找出此页面的逻辑:存储了大约 ++ 100 个结果 - 并使用 Python 和 BS4 进行了解析
    试图找出此页面背后的逻辑:我们已将一些结果存储在以下数据库中:https://www.raiffeisen.ch/rch/de/ueber-uns/raiffeisen-gruppe/Organization/raiffeisenbanken/deutsche-schweiz.html#accordionitem_18104049731620873397从a到z大约:120个结果或更多:......
  • 如何在 Numpy Python 中将 4 维数组的下三角形复制到上三角形?
    目标是将下三角形复制到上三角形。根据OP中提出的建议,起草了以下代码。importnumpyasnplw_up_pair=np.tril_indices(4,-1)arr=np.zeros((4,4,1,1))arr[1,:1,:,0]=1arr[2,:2,0,0]=2arr[3,:3,0,0]=3arr=arr+arr.T-np.diag(np.diag(arr))但是,它......
  • 如何在 Python 中对多行使用单个 INSERT INTO 语句?
    我目前正在开发一个DiscordPython机器人,我在其中循环遍历ForumTags列表,并为每个对象生成INSERTINTOSQL语句以将数据插入MySQL数据库。但是,我想要通过将所有这些单独的INSERTINTO语句组合到单个查询中来优化我的代码,如下所示:INSERTINTO......
  • 双 for 循环的 Pythonic 方式
    我有以下代码:importnumpyasnpepsilon=np.array([[0.,0.00172667,0.00071437,0.00091779,0.00154501],[0.00128983,0.,0.00028139,0.00215905,0.00094862],[0.00035811,0.00018714,0.,0.00029365,0.00036993......