python 如何删除excel中带有删除线的特定字符串保留没有删除线的单词

python 如何删除excel中带有删除线的特定字符串保留没有删除线的单词
注意:经验证 Mac必须安装Microsoft Excel app 但不一定OK

import xlwings as xw


wb = xw.Book('file.xlsx')
ws = wb.sheets('Sheet1')

for cell in ws.range('A1:B3'):
    cell_coord = str(cell.address.replace('$', ''))
    print('Cell: ' + cell_coord + ', Cell value: ' + str(cell.value), end=', ')

    # 判断单元格是否有删除线
    st = cell.font.impl.xl.Strikethrough
    print('ST value: ' + str(st), end=' ')
    if st:
        print(', 单元格有删除线字体.')
        cell.clear()
    # 如果单元格是正常和删除线的混合,则它是None,
    elif st is None:
        print(', 单元格有混合字体.')
        num_chars = len(cell.value)
        print(cell_coord + ' Text length: ' + str(num_chars) + ' characters.')
        print("个别字符字体有删除线?")
        
        # 检测单元格有混合字体中的带有删除线的个别字符串
        char_position = 0
        while True:
            cur_text_value = cell.characters[char_position].text
            if cur_text_value == '':
                break
            else:
                print("'" + cur_text_value + "'", end=' ')
                char_is_st_font = cell.characters[char_position].font.impl.xl.Strikethrough
                print(char_is_st_font)

                if char_is_st_font:
                    cell.characters[char_position].api.Delete()
                else:
                    char_position += 1
    # 否则不存在
    else:
        print(', 单元格没有删除线字体.')

wb.save('file2.xlsx')
wb.close()

在这里插入图片描述

在这里插入图片描述

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 你可以使用 Python 的 openpyxl 库来删除 Excel 带有删除线的字符。 首先,安装 openpyxl 库: ``` pip install openpyxl ``` 然后,使用下面的代码打开 Excel 文件并遍历所有单元格: ``` import openpyxl # 打开 Excel 文件 workbook = openpyxl.load_workbook('文件名.xlsx') # 遍历所有工作表 for sheet in workbook: # 遍历所有单元格 for row in sheet: for cell in row: # 如果单元格带有删除线,则将其删除 if cell.font.strikethrough: cell.value = None # 保存修改后的 Excel 文件 workbook.save('新文件名.xlsx') ``` 希望这能帮到你! ### 回答2: 要使用Python语言删除Excel带有删除线的字符,可以使用openpyxl库来实现。下面是一个示例代码: ```python from openpyxl import load_workbook # 打开Excel文件 wb = load_workbook('example.xlsx') # 选择要处理的工作表 ws = wb['Sheet1'] # 遍历工作表的每个单元格 for row in ws.iter_rows(): for cell in row: # 检查是否有删除线 if cell.font.strike: # 删除删除线 cell.font = cell.font.copy(strike=False) # 保存修改后的Excel文件 wb.save('example_modified.xlsx') ``` 在上述代码,需要确保已经安装了openpyxl库。首先通过load_workbook函数打开Excel文件,然后使用wb['Sheet1']选择要处理的工作表。接下来,使用两层循环遍历工作表的每个单元格。判断cell.font.strike属性是否为True,即判断该单元格是否带有删除线。如果带有删除线,通过将cell.font.strike属性设置为False来删除删除线。最后,使用wb.save函数保存修改后的Excel文件。 这样,就可以用Python语言删除Excel带有删除线的字符了。 ### 回答3: 使用Python可以使用openpyxl库来读取和编辑Excel文件。要删除带有删除线的字符,你可以按照以下步骤操作: 安装openpyxl库(如果你还没有安装):可以使用pip install openpyxl命令在命令行安装openpyxl库。 导入openpyxl库:在python文件,使用import openpyxl语句导入openpyxl库。 打开Excel文件:使用openpyxl库提供的load_workbook函数打开Excel文件,并将其保存到一个变量。 选择工作表:根据需要选择要操作的工作表。可以使用.worksheets方法获取工作表的列表,然后根据工作表的位置或名称选择要操作的特定工作表。 遍历单元格:使用工作表的.iter_rows方法遍历所有单元格。如果你只想遍历特定的行或列,也可以使用.iter_rows(min_row, max_row, min_col, max_col)方法。 检查单元格属性:对于每个单元格,使用font属性来检查是否存在删除线。如果.font.strike属性为True,则表示存在删除线删除带有删除线的字符:如果发现带有删除线的字符,可以使用.value属性将其值设置为空字符串或其他要替换的值。 保存修改后的Excel文件:使用workbook的.save方法将修改后的Excel文件保存。 下面是用Python删除Excel带有删除线的字符的代码示例: ```python import openpyxl # 打开Excel文件 workbook = openpyxl.load_workbook('文件路径/文件名.xlsx') # 选择要操作的工作表 worksheet = workbook['工作表名称'] # 遍历所有单元格 for row in worksheet.iter_rows(): for cell in row: # 检查单元格是否有删除线 if cell.font.strike: # 删除带有删除线的字符,这里将其值设置为为空字符串 cell.value = '' # 保存修改后的Excel文件 workbook.save('文件路径/修改后的文件名.xlsx') ``` 请注意,代码的文件路径需要根据实际情况进行修改。另外,openpyxl库还提供了其他一些功能,你可能需要根据具体情况进行更多的定制和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Ko-walski

太难了,求鼓励

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值