第一章:整行插入与删除
① Excel 的插入行实例演示
插入行演示采用正序遍历操作,直接使用 xlwings 提供的 sheet.api.Rows("行数").Insert() 方法就能实现整行插入处理。
需要注意的是,如果是前插入,要避免再次检测到刚才匹配过的内容,以防循环反复插入原位置。
import xlwings
app = xlwings.App(visible=False)
path_xl = 'C:\Users\Administrator\Desktop\增、删行测试.xls'
wt = app.books.open(path_xl)
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
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;
xl_insert('C', '//*[@fieldid="header-area"]//*[@fieldid="Add_btn"]')
wt.save()
wt.close()
调整前:
处理过程:
调整后:
② Excel 的删除行实例演示
删除行演示采用逆序遍历操作,直接使用 xlwings 提供的 sheet.range("单元格").api.EntireRow.Delete() 方法就能实现整行删除处理。
此次使用逆序遍历,直接避免了行错位引起的各种问题。【推荐】
import xlwings
app = xlwings.App(visible=False)
path_xl = 'C:\Users\Administrator\Desktop\增、删行测试.xls'
wt = app.books.open(path_xl)
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;
xl_delete('D', 'gys_qj_sckh002')
wt.save()
wt.close()
调整前:
处理过程:
调整后:
|