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)
运行结果显示
为电话号码(打了个码)