excel文件合并——单一选项合并python

代码

#引入包
import numpy as np
import pandas as pd
import xlrd
import xlwt
#打开excel表格

    #df=pd.DataFrame(pd.read_csv('name.csv',header=1))
    #df=pd.DataFrame(pd.read_excel('文件.xlsx'))
    
    
    #请输入excel文件地址,读操作
data = xlrd.open_workbook('文件.xlsx')
    #写操作

#返回单元格的值
#函数参数输入参数分别为sheet=1表示excel中sheet1,
def value(sheet,cell_row,cell_column,data):

    
    sheet=sheet-1
    cell_row=cell_row-1
    cell_column=cell_column-1
    
    #table表示sheet1
    table = data.sheets()[sheet]
    #table.cell(0,0)表示
    cell= table.cell(cell_row,cell_column)
    #table.cell_value表示excel单元格的值
    #cell_value = table.cell_value(0,0)
    result=table.cell_value(cell_row,cell_column)
    return result

#返回行数sheet默认值为1,即为sheet1的数据
#返回sheet的行数
def row(data,sheet):
    sheet=sheet-1
    table = data.sheets()[sheet]
    row_sum = table.nrows
    return row_sum
#返回sheet的列数
def column(data,sheet):
    sheet=sheet-1
    table = data.sheets()[sheet]
    row_len = table.row_len(0)
    return row_len

#按某一列进行查找
#返回其所在行数
def find_row_in_column(data,sheet,column1,value1):
    sheet=sheet-1
    for i in range(1,row(data,sheet+1)):
        if value1==value(sheet,i,column1,data):
            return i
        return 0

def xie(data,sheet,cell_row,cell_column,value):
    #table表示sheet1
    sheet=sheet-1
    table = data.sheets()[sheet]
    table.cell(row=cell_row,column=cell_column).value=value
    data.save()

#write_string()
#write_number()
#write_blank()
#write_formula()
#write_datetime()
#write_boolean()
#write_url()

#函数value(sheet,cell_row,cell_column,data)、find_row_in_column(data,sheet,column1,value1)

目的:按sheet2中的学号的顺序在sheet1中查找相应的电话号码

sheet2

在这里插入图片描述

sheet1

在这里插入图片描述

#按列查找元素,输出对应元素所在i行的元素,输出到excel的一行中
#excel表格合并某一项元素
def combine_1(data,sheet1,sheet2,column1,column1_1,column2,row1=1,row2=1):
    #sheet1表示主表格信息,sheet2表示需要查找表格的信息
    #column1表示主表格所查询的列,column1_1为查找表格中对应column1的列数
    #column2表示查找表格中需要copy的元素所在的列
    #column2_2表示第三步找到的元素需要放置于sheet1中的行数
    
    #****************  rang中的1可以根据实际情况变更,为默认为1 ,起始行数
    
    #元素所在列的表头名称 ——默认为该列第一行
    print(value(sheet2,1,column2,data))
    for i in range(row1,row(data,sheet1)):
        #循环sheet1中column1列的元素为value_sheet1
        for j in range(row2,row(data,sheet2)):
            if value(sheet1,i,column1,data)==value(sheet2,j,column1_1,data):
                #将对应元素的行中的column2行所在的元素赋值给zhjian
                zhjian=int(value(sheet2,j,column2,data))
                print(zhjian)
                break
        #将zhjian填写到主表格sheet1中
        
    
#excel表格合并最终函数

#比对数字(学号。。)可能会出错,需要在excel中运用value函数进行数据的预处理
#参数信息
#例如:对比sheet1总表格中按照学号所在列column1,与sheet2分表中的学号所在列column1_1
#将sheet2中与column1相对应元素所具备的一个属性打印(该属性所在列为column2)
#data,sheet1(主填写sheet),sheet2(寻找信息的sheet),column1(主填写区域中查找),对应打印的内容——column2(对应column1元素所具备的属性)
#row1(sheet1对应的起始行数,默认值为1),row2(sheet2对应的起始行数,默认值为1)
combine_1(data,2,1,4,2,8,4,2)

运行结果显示

为电话号码(打了个码)
运行结果

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值