Python操作excel进行插入、删除行操作实例演示,利用xlwings库实现

第一章:整行插入与删除

① Excel 的插入行实例演示

插入行演示采用正序遍历操作,直接使用 xlwings 提供的 sheet.api.Rows("行数").Insert() 方法就能实现整行插入处理。
需要注意的是,如果是前插入,要避免再次检测到刚才匹配过的内容,以防循环反复插入原位置。

# -*- coding:utf-8 -*-
# excel增行、删行实现

import xlwings

# 参数visible设置False不显示excel界面,默认是True显示的
app = xlwings.App(visible=False)
# 修改文件路径
path_xl = 'C:\\Users\\Administrator\\Desktop\\增、删行测试.xls'
# 加载excel文件
wt = app.books.open(path_xl)
# 加载第一个sheet页签
sheet = wt.sheets[0]

def xl_insert(m_col, m_text):
    '''
     作用:插入excel
     参数1:需要匹配的列
     参数2:需要匹配的内容
    ····
     创建:小蓝枣
     更改:2021-06-01
    '''
    global sheet;
    
    # 读取行数
    rows = sheet.used_range.last_cell.row

    # 如果从n行上面插入,需要想办法跳过n+1这一行,n+1正是插入后原来n行的脚本,不然会发生死循环
    k = 0   # 记录插入行
    for i in range(1, rows):
        
        # 检测到已插入的行进行跳过处理
        if(i == k):
            continue;
            
        if(sheet.range(m_col + str(i)).value == m_text):
            print("对第 " + str(i) + " 行进行了插入行操作!")
            sheet.api.Rows(i).Insert()
            k = i+1;

# 匹配C列,对相关内容进行插入
xl_insert('C', '//*[@fieldid="header-area"]//*[@fieldid="Add_btn"]')

# 不指定路径,脚本会直接保存到原文件
wt.save()
# 释放资源,不然脚本无法打开,会处于锁定状态。
wt.close()

调整前:
在这里插入图片描述
处理过程:
在这里插入图片描述
调整后:
在这里插入图片描述

② Excel 的删除行实例演示

删除行演示采用逆序遍历操作,直接使用 xlwings 提供的 sheet.range("单元格").api.EntireRow.Delete() 方法就能实现整行删除处理。
此次使用逆序遍历,直接避免了行错位引起的各种问题。【推荐】

# -*- coding:utf-8 -*-
# excel增行、删行实现

import xlwings

# 参数visible设置False不显示excel界面,默认是True显示的
app = xlwings.App(visible=False)
# 修改文件路径
path_xl = 'C:\\Users\\Administrator\\Desktop\\增、删行测试.xls'
# 加载excel文件
wt = app.books.open(path_xl)
# 加载第一个sheet页签
sheet = wt.sheets[0]

def xl_delete(m_col, m_text):
    '''
     作用:excel删行
     参数1:需要匹配的列
     参数2:需要匹配的内容
    ····
     创建:小蓝枣
     更改:2021-06-01
    '''
    global sheet;
    
    # 读取行数
    rows = sheet.used_range.last_cell.row
    # 正序的话本行删除后,后面的行就有变化了,采用倒叙匹配解决了该问题
    for i in range(rows, 1, -1):
        if(sheet.range(m_col + str(i)).value == m_text):
            print("对第 " + str(i) + " 行进行了删除行操作!")
            sheet.range(m_col + str(i)).api.EntireRow.Delete()
            k = i+1;

# 匹配C列,对相关内容进行删行
xl_delete('D', 'gys_qj_sckh002')

# 不指定路径,脚本会直接保存到原文件
wt.save()
# 释放资源,不然脚本无法打开,会处于锁定状态。
wt.close()

调整前:
在这里插入图片描述
处理过程:
在这里插入图片描述
调整后:
在这里插入图片描述
喜欢的点个赞❤吧!

  • 73
    点赞
  • 343
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 18
    评论
### 回答1: 您可以使用 Python 的 openpyxl 操作 Excel 文件。 首先,使用 openpyxl 打开 Excel 文件: ```python import openpyxl wb = openpyxl.load_workbook('file.xlsx') ``` 然后,可以使用 openpyxl 读取 Excel 文件中的数据。比如,可以使用下面的代码来读取第一张表中的数据: ```python sheet = wb.get_sheet_by_name('Sheet1') for row in sheet.rows: cell1 = row[0].value cell2 = row[1].value # 在这里检查是否满足条件 ``` 接着,您可以使用 openpyxl 创建一个新的 Excel 文件,然后将满足条件的数据写入新文件中: ```python new_wb = openpyxl.Workbook() new_sheet = new_wb.active for row in sheet.rows: cell1 = row[0].value cell2 = row[1].value if cell1 == cell2 * 2: new_sheet.append([cell1, cell2]) new_wb.save('new_file.xlsx') ``` 这样就可以使用 Python 操作 Excel 文件,搜索满足条件的数据并生成一个新的 Excel 文件了。 ### 回答2: 使用Python操作Excel文件可以使用第三方`openpyxl`来实现。下面是一个简单的示例代码: ```python import openpyxl # 打开原始Excel文件 wb = openpyxl.load_workbook("原始文件.xlsx") ws = wb.active # 创建新的Excel文件 new_wb = openpyxl.Workbook() new_ws = new_wb.active # 遍历原始文件的每一数据 for row in ws.iter_rows(values_only=True): # 判断列1是否是列2的两倍 if row[0] == 2 * row[1]: # 将满足条件的数据写入新的Excel文件 new_ws.append(row) # 保存新的Excel文件 new_wb.save("新文件.xlsx") ``` 上述代码首先导入`openpyxl`,然后使用`load_workbook`函数打开原始Excel文件,并通过`active`属性获取当前活动的工作表。接着使用`Workbook`函数创建一个新的Excel文件,再使用`active`属性获取新文件的活动工作表。 代码中通过遍历原始工作表的每一数据,使用条件判断语句`if`判断第一列的值是否等于第二列的两倍。如果满足条件,则使用`append`函数将该数据添加到新的工作表中。 最后,使用`save`函数将新的工作簿保存为新的Excel文件。请注意,你需要将"原始文件.xlsx"替换为你实际的原始Excel文件名,并将"新文件.xlsx"替换为你想要保存的新的Excel文件名。 使用这段代码可以筛选出满足条件的数据,并生成一个新的Excel文件。 ### 回答3: 在Python操作Excel文件,可以使用第三方openpyxl来实现。首先,需要导入openpyxl: ```python import openpyxl ``` 然后,读取原始Excel文件的内容: ```python # 打开原始Excel文件 wb = openpyxl.load_workbook('原始文件.xlsx') # 选择工作表 ws = wb.active ``` 接下来,创建一个新的Excel文件并定义工作表: ```python # 创建新的Excel文件 new_wb = openpyxl.Workbook() # 选择工作表 new_ws = new_wb.active ``` 然后,对原始Excel文件中的每一进行遍历,判断满足条件的,并将这些添加到新的Excel文件中: ```python # 遍历每一 for row in ws.iter_rows(): # 判断列1是否是列2的两倍 if row[0].value == row[1].value * 2: # 将符合条件的添加到新的Excel文件中 new_ws.append([cell.value for cell in row]) ``` 最后,保存新的Excel文件: ```python # 保存新的Excel文件 new_wb.save('新文件.xlsx') ``` 以上是用Python操作Excel文件,搜索满足列1是列2两倍的条件并生成一个新的Excel文件的方法。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

挣扎的蓝藻

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值