import win32com.client as win32
def select_and_color_cells(file_path, sheet_name, search_text):
# Create a new Excel application
excel = win32.Dispatch("Excel.Application")
# Open the workbook
workbook = excel.Workbooks.Open(file_path)
# Select the active sheet
sheet = workbook.Sheets(sheet_name)
# 获取第一列的范围
first_column_range = sheet.Range(sheet.Cells(1, 1), sheet.Cells(sheet.UsedRange.Rows.Count, 1))
# 将第一列的值读取到一个 Python 列表中
first_column_list = [str(cell.Value) for cell in first_column_range]
print('first_column_list',first_column_list)
new_list = []
for index, value in enumerate(first_column_list):
if value and search_text in value:
# 将单元格的背景色设为绿色
new_list.append(index)
#
new_list = [f"A{index + 1}" for index in new_list]
print('new_list',new_list)
color = 65535 # 背景色,这里使用颜色的索引,65535代表黄色
# 将所有要设置背景色的单元格地址拼接成一个字符串
cell_range = ",".join(new_list)
# 使用 Range 对象的 Union 方法获取所有要设置背景色的单元格范围
cells = sheet.Range(cell_range)
# 设置背景色
cells.Interior.Color = color
# Example usage
file_path = r"C:\Users\Administrator\Documents\Book1 - 副本.xlsx"
sheet_name = "Sheet1" # Replace with the name of your sheet
search_text = "11"
select_and_color_cells(file_path, sheet_name, search_text)
import win32com.client as win32
def set_cell_background_color(file_path, sheet_name, cell_addresses, color):
excel = win32.gencache.EnsureDispatch("Excel.Application")
excel.Visible = True
workbook = excel.Workbooks.Open(file_path)
sheet = workbook.Worksheets(sheet_name)
try:
color = 65535 # 背景色,这里使用颜色的索引,65535代表黄色
# 将所有要设置背景色的单元格地址拼接成一个字符串
cell_range = ",".join(cell_addresses)
# 使用 Range 对象的 Union 方法获取所有要设置背景色的单元格范围
cells = sheet.Range(cell_range)
# 设置背景色
cells.Interior.Color = color
except Exception as e:
print(f"Error occurred: {str(e)}")
finally:
# workbook.Save()
# excel.Quit()
pass
# 使用示例
file_path = r"C:\Users\Administrator\Documents\Book1 - 副本.xlsx"
sheet_name = "Sheet1"
cell_addresses = ["A1", "B3", "C5", "D7"] # 非连续的单元格地址列表
color = 65535 # 背景色,这里使用颜色的索引,65535代表黄色
set_cell_background_color(file_path, sheet_name, cell_addresses, color)
# 示例用法
file_path = r"C:\Users\Administrator\Documents\Book1 - 副本.xlsx"
sheet_name = "Sheet1" # 替换为您的工作表名称
search_text = "11"
文章来源地址https://www.toymoban.com/news/detail-606077.html
文章来源:https://www.toymoban.com/news/detail-606077.html
到了这里,关于python 设置 win32 excel 设置 非连续单元格 背景色的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!