python处理Excel~输出相同内容的序号(xlrd,xlwt)

问题需求

在Excel里面,有一列(行)是文字信息,需要去掉题号(部分内容)。然后第一行是题干,需要将第一行题干去掉,然后内容用双层for循环进行遍历,找到相同内容的题干号,从而删除相同的题号(目前没有尝试在python中删除内容相同的行,只是查询到,然后手动在Excel里面删除。)
主要用到比较老的库(xlrd,xlwt)

注意点

老的库不支持xlsx格式的Excel,只能支持xls

思路

step1:必须先获取需要比较内容(行/列),并将第一行的(题干去掉),代码如下:

import  xlrd,xlwt
wb=xlrd.open_workbook('~~~~.xls')#需要导入的Excel文件
ws=wb.sheet_by_name('Sheet1') #通过名字获取表
nwb=xlwt.Workbook(encoding='utf-8')#格式选择utf-8格式(保证另存为其他Excel的时候不出现乱码)
nws=nwb.add_sheet('Sheet1')#创建新工作簿的表
n=0
m=0
while n<ws.nrows-1:
    n+=1  #因为进入while循环的时候,n已经为1,这一步主要是为了去掉第一行的‘题干’
    nws.write(m,1,ws.cell_value(n,1)) 
    # m代表的是行,‘1’代表我需要提取第一列(注意python是从0开始计数),ws.cell_value(n,1)获取内容
    m+=1
nwb.save('C:\\Users\\Dell\\Desktop\\1235.xls') #提取出来的比较信息的行/列(存放的位置)

step2:将获取到的‘1235.xls’,去掉题号。例如1.啦啦啦;2.哈哈哈; 我们需要去掉前面‘1.’,每个题目的格式都是这样,所以我只需要从2开始读取,我们刚才提取的内容,代码如下:

import  xlrd,xlwt
wb=xlrd.open_workbook('1235.xls') #读取刚才的Excel
ws=wb.sheet_by_name('Sheet1') #通过名字获取表
nwb=xlwt.Workbook(encoding='utf-8') 
nws=nwb.add_sheet('Sheet1')
col=ws.col_values(1)  #获取第一列的数据(注python是从0开始计数)
n=0
for i in col:
    nws.write(n,1,ws.cell_value(n,1)[2:]) 
    #n代表行数, 1代表列数 
    #cell_value(n,1)是为了获取cell里面的值,cell_value(n,1)[2:]后面加[2:] 去掉题号。
    n+=1
nwb.save('C:\\Users\\Dell\\Desktop\\12346.xls') #保存的新的地址

step3:准备工作都做完,现在就是比较内容,利用双层for循环,外层循环控制第一个比较数,内层是整个lst遍历,代码如下:
(可以在该代码进行改进,直接去掉重复的题干,但是需要导入xlwt模块)

import  xlrd
wb=xlrd.open_workbook('12346.xls')
ws=wb.sheet_by_name('Sheet1')
lst=ws.col_values(1)
for i in range(len(lst)-2):    #这个双层循环,可以参考一哈冒泡排序
   for x in range(len(lst)-1):
      if  i!=x+1:
         if lst[i].__eq__(lst[x+1]):  #比较内容是否相当(即比较值),切记勿用‘==’,这个是比较地址
            print(i+1,x+2)  #由于前期我去掉‘题干的行’,在原表查找的时候需要+1
      else:
         print('')

我没有对每个函数进行封装,每个步骤可以进行封装,再输入点提示性框,一次运行搞定所有。由于是理解,我就拆分写。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值