python中有将两列数据合并为一列数据的函数么
假设数据在文件 test.txt中,程序(测试,大这么个意思)
lines=open(r'test.txt').readlines()
text=[]
for line in lines:
word=line.split()
thirdword=word[2].strip()
text.append(thirdword)
result=''.join(text)
print result
如何用python从excel中同时提取两个列的数据,并生成dict(用xlrd)
import xlrd
data = xlrd.open_workbook('excelFile.xls')
table = data.sheet_by_index(0) #索引顺序表
colnumber_b = ord('B')-ord('A')
colnumber_g = ord('G')-ord('A')
score_dict = {}
for i in range(100): #前一百行
score_dict[table.cell(i,colnumber_b).value]=table.cell(i,colnumber_g).value
python pandas 怎么读取excel的合并单元格数据
xlrd和xlwt两个中,可以选择合并单元格的行数,判断合并的行数貌似把,它用xlrd读,尽管合并了但是读取是还是一行一行读的,只是合并后的数据读取时是在第一行中读取到的,接下来的都为空
python如何读取多个excel合并到一个excel中
思路
python xlrd包excle,然后将文件内容存入一个列表中,再利用xlsxwriter将内容写入到一个新的excel文件中。
完整代码
# -*- coding: utf-8 -*-#将多个Excel文件合并成一个import xlrdimport xlsxwriter#打开一个excel文件def open_xls(file):
fh=xlrd.open_workbook(file) return fh#获取excel中所有的sheet表def getsheet(fh):
return fh.sheets()#获取sheet表的行数def getnrows(fh,sheet):
table=fh.sheets()[sheet] return table.nrows#读取文件内容并返回行内容def getFilect(file,shnum):
fh=open_xls(file)
table=fh.sheets()[shnum]
num=table.nrows for row in range(num):
rdata=table.row_values(row)
datavalue.append(rdata) return datavalue#获取sheet表的个数def getshnum(fh):
x=0
sh=getsheet(fh) for sheet in sh:
x =1
return xif __name__=='__main__': #定义要合并的excel文件列表
allxls=['F:/test/excel1.xlsx','F:/test/excel2.xlsx'] #存储所有读取的结果
datavalue=[] for fl in allxls:
fh=open_xls(fl)
x=getshnum(fh) for shnum in range(x):
print("正在读取文件:" str(fl) "的第" str(shnum) "个sheet表的内容...")
rvalue=getFilect(fl,shnum) #定义最终合并后生成的新文件
endfile='F:/test/excel3.xlsx'
wb1=xlsxwriter.Workbook(endfile) #创建一个sheet工作对象
ws=wb1.add_worksheet() for a in range(len(rvalue)): for b in range(len(rvalue[a])):
c=rvalue[a][b]
ws.write(a,b,c)
wb1.close()
print("文件合并完成")1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
源文件excel1:
源文件excel2:
运行结果:
合并后的excel3: