python怎么读取excel的数据 用python读取excel,怎样显示要查找的数据

python \u5982\u4f55\u8bfb\u53d6 excel \u6307\u5b9a\u5355\u5143\u683c\u5185\u5bb9

1\u3001\u9996\u5148\u6253\u5f00\u7535\u8111\u4e0a\u7f16\u5199python\u7684\u8f6f\u4ef6\u3002

2\u3001\u7136\u540e\u65b0\u5efa\u4e00\u4e2apy\u6587\u4ef6\uff0c\u5982\u4e0b\u56fe\u6240\u793a\u3002

3\u3001\u63a5\u7740\u5c31\u662f\u5bfc\u5165xlrd\u5305\uff0c\u8bfb\u53d6\u8868\u683c\u7684\u51fd\u6570\u5c31\u5728\u8fd9\u91cc\u9762\uff0c\u5982\u4e0b\u56fe\u6240\u793a\u3002

4\u3001\u7136\u540e\u5c31\u662f\u6253\u5f00\u60f3\u8981\u8bfb\u53d6\u7684\u8868\u683c\uff0c\u5982\u4e0b\u56fe\u6240\u793a\u3002

5\u3001\u63a5\u7740\u5c31\u662f\u6307\u5b9a\u8981\u8bfb\u53d6\u4e00\u4e2aexcel\u8868\u4e2d\u7684\u90a3\u4e2a\u8868\u683c\u3002

6\u3001\u7136\u540e\u5c31\u662f\u6839\u636esheet\u7d22\u5f15\u83b7\u53d6sheet\u5185\u5bb9\u3002

7\u3001\u6700\u540e\u5c31\u662f\u8bfb\u53d6\u4e00\u4e2a\u8868\u683c\u4e2d\u7684\u884c\u6216\u5217\u7684\u503c\uff0c\u5c31\u5b8c\u6210\u4e86\u3002

\u5c31\u662f\u628axls or xlsx\u53e6\u5b58\u4e3aCSV\u683c\u5f0f\uff0c\u7136\u540e\u518d\u68c0\u7d22\u3002\u4ee3\u7801\u5982\u4e0b\uff0c\u629b\u7816\u5f15\u7389\u3002

# -*- coding: cp936 -*-
import linecache
o=open('d:\\test\\14.csv')#\u6587\u4ef6\u8def\u5f84
o.seek(0)
r=o.readlines()
s1=str(input('\u8f93\u5165\u8981\u5b9a\u4f4d\u7684\u4fe1\u606f:'))
a=0
count=0
for i in r: #\u6309\u548c\u503c\u7ec4\u5408\u67e5\u627e
if i.find(s1)>=0:
print r[a-1]#\u663e\u793a\u4e0a\u4e00\u884c
print i#\u663e\u793a\u5b9a\u4f4d\u884c
print r[a+1]#\u663e\u793a\u4e0b\u4e00\u884c
a+=1
print 'Total:%d'%count

\u4f8b\uff1a
\u5728\u4ee5\u4e0b\u6570\u636e\u4e2d\uff0c\u67e5\u627e\u542b\u6709T\u7684\u884c\uff0c\u5e76\u663e\u793a\u4e0a\u4e00\u884c\uff08n\u884c\uff09 or \u4e0b\u4e00\u884c\uff08n\u884c) \u3002
1\uff0c2\uff0c3\uff0c4
W,R,GFR,T
12,,F,34,G
\u8fd9\u4e2a\u5c31\u7528\u4e0a\u9762\u7684\u4ee3\u7801\u5c31\u884c\u4e86\u3002

最近由于经常要用到Excel,需要根据Excel表格中的内容对一些apk进行处理,手动处理很麻烦,于是决定写脚本来处理。首先贴出网上找来的读写Excel的脚本。
1.读取Excel(需要安装xlrd):

123456789101112131415161718192021222324

#-*- coding: utf8 -*-import xlrd  fname = "reflect.xls"bk = xlrd.open_workbook(fname)shxrange = range(bk.nsheets)try: sh = bk.sheet_by_name("Sheet1")except: print "no sheet in %s named Sheet1" % fname#获取行数nrows = sh.nrows#获取列数ncols = sh.ncolsprint "nrows %d, ncols %d" % (nrows,ncols)#获取第一行第一列数据cell_value = sh.cell_value(1,1)#print cell_value  row_list = []#获取各行数据for i in range(1,nrows): row_data = sh.row_values(i) row_list.append(row_data)

2.写入Excel(需安装pyExcelerator)

12345678

from pyExcelerator import * w = Workbook()  #创建一个工作簿ws = w.add_sheet('Hey, Hades')  #创建一个工作表ws.write(0,0,'bit') #在1行1列写入bitws.write(0,1,'huang') #在1行2列写入huangws.write(1,0,'xuan') #在2行1列写入xuanw.save('mini.xls')  #保存

3.再举个自己写的读写Excel的例子
读取reflect.xls中的某些信息进行处理后写入mini.xls文件中。 

1234567891011121314151617181920212223242526272829303132333435363738394041424344

#-*- coding: utf8 -*-import xlrdfrom pyExcelerator import *  w = Workbook()ws = w.add_sheet('Sheet1') fname = "reflect.xls"bk = xlrd.open_workbook(fname)shxrange = range(bk.nsheets)try: sh = bk.sheet_by_name("Sheet1")except: print "no sheet in %s named Sheet1" % fname nrows = sh.nrowsncols = sh.ncolsprint "nrows %d, ncols %d" % (nrows,ncols)  cell_value = sh.cell_value(1,1)#print cell_value  row_list = []mydata = []for i in range(1,nrows): row_data = sh.row_values(i) pkgdatas = row_data[3].split(',') #pkgdatas.split(',') #获取每个包的前两个字段 for pkgdata in pkgdatas:  pkgdata = '.'.join((pkgdata.split('.'))[:2])  mydata.append(pkgdata) #将列表排序 mydata = list(set(mydata)) print mydata #将列表转化为字符串 mydata = ','.join(mydata) #写入数据到每行的第一列 ws.write(i,0,mydata) mydata = [] row_list.append(row_data[3])#print row_list w.save('mini.xls')

4.现在我需要根据Excel文件中满足特定要求的apk的md5值来从服务器获取相应的apk样本,就需要这样做: 

123456789101112131415161718192021222324252627282930313233

#-*-coding:utf8-*-import xlrdimport osimport shutil  fname = "./excelname.xls"bk = xlrd.open_workbook(fname)shxrange = range(bk.nsheets)try: #打开Sheet1工作表 sh = bk.sheet_by_name("Sheet1")except: print "no sheet in %s named Sheet1" % fname#获取行数nrows = sh.nrows#获取列数ncols = sh.ncols#print "nrows %d, ncols %d" % (nrows,ncols)#获取第一行第一列数据cell_value = sh.cell_value(1,1)#print cell_value  row_list = []#range(起始行,结束行)for i in range(1,nrows): row_data = sh.row_values(i) if row_data[6] == "HXB":  filename = row_data[3]+".apk"  #print "%s %s %s" %(i,row_data[3],filename)  filepath = r"./1/"+filename  print "%s %s %s" %(i,row_data[3],filepath)  if os.path.exists(filepath):   shutil.copy(filepath, r"./myapk/")

补充一个使用xlwt3进行Excel文件的写操作。

1234567891011121314151617181920212223242526

import xlwt3 if __name__ == '__main__':         datas = [['a', 'b', 'c'], ['d', 'e', 'f'], ['g', 'h']]#二维数组    file_path = 'D:\est.xlsx'         wb = xlwt3.Workbook()    sheet = wb.add_sheet('test')#sheet的名称为test         #单元格的格式    style = 'pattern: pattern solid, fore_colour yellow; '#背景颜色为黄色    style += 'font: bold on; '#粗体字    style += 'align: horz centre, vert center; '#居中    header_style = xlwt3.easyxf(style)         row_count = len(datas)    col_count = len(datas[0])    for row in range(0, row_count):        col_count = len(datas[row])        for col in range(0, col_count):            if row == 0:#设置表头单元格的格式                sheet.write(row, col, datas[row][col], header_style)            else:                sheet.write(row, col, datas[row][col])    wb.save(file_path)

输出的文件内容如下图:

注:以上代码在Python 3.x版本测试通过。

好了,python操作Excel就这么!些了,简单吧



  • python濡備綍璇诲彇excel閲岄潰鏌愪竴鏁村垪鍐呭骞朵慨鏀?
    绛旓細鍙互浣跨敤 Python 涓殑 pandas 搴撴潵璇诲彇 Excel 鏂囦欢閲岄潰鏌愪竴鏁村垪鍐呭骞朵慨鏀广傞鍏堬紝闇瑕佸畨瑁 pandas 搴撱傚湪鍛戒护琛屼腑杈撳叆锛歱ip install pandas 鐒跺悗鍙互浣跨敤 pandas 鐨 read_excel 鍑芥暟璇诲彇 Excel 鏂囦欢锛屽苟浣跨敤 iloc 灞炴ц幏鍙栨煇涓鏁村垪鍐呭銆備笅闈㈡槸涓涓ず渚嬩唬鐮侊細import pandas as pd 璇诲彇 Excel 鏂囦欢 df...
  • python璇诲彇excel鏌愪釜鏃堕棿鑼冨洿鍚
    绛旓細鏄殑銆Python鍙互璇诲彇Excel涓煇涓椂闂磋寖鍥寸殑鏁版嵁銆傚彲浠ヤ娇鐢≒ython涓殑pandas搴撴潵璇诲彇Excel鏂囦欢锛屽苟浣跨敤鏉′欢杩囨护鍣ㄦ潵绛涢夊嚭鏌愪釜鏃堕棿鑼冨洿鍐呯殑鏁版嵁銆
  • python鎬庝箞璇诲啓褰撳墠鐨excel
    绛旓細python鏈夊緢寮哄ぇ鐨excel璇诲啓鑳藉姏锛屽彧闇瑕佸畨瑁厁lrd锛寈lwt杩欎袱涓簱灏卞彲浠ヤ簡 pip install xlrdPip install xlwt鐪嬫暀绋嬶紝鍦ㄥ彸杈圭殑閾炬帴锛氱綉椤甸摼鎺 ecoding=utf-8import sysreload(sys)sys.setdefaultencoding('utf-8')from pyExcelerator import *w = Workbook() #鍒涘缓涓涓伐浣滅翱ws = w.add_sheet('1')...
  • python 濡備綍璇诲彇 excel 鎸囧畾鍗曞厓鏍煎唴瀹
    绛旓細1銆侀鍏堟墦寮鐢佃剳涓婄紪鍐python鐨勮蒋浠躲2銆佺劧鍚庢柊寤轰竴涓猵y鏂囦欢锛屽涓嬪浘鎵绀恒3銆佹帴鐫灏辨槸瀵煎叆xlrd鍖咃紝璇诲彇琛ㄦ牸鐨勫嚱鏁板氨鍦ㄨ繖閲岄潰锛屽涓嬪浘鎵绀恒4銆佺劧鍚庡氨鏄墦寮鎯宠璇诲彇鐨勮〃鏍硷紝濡備笅鍥炬墍绀恒5銆佹帴鐫灏辨槸鎸囧畾瑕佽鍙栦竴涓excel琛ㄤ腑鐨勯偅涓〃鏍笺6銆佺劧鍚庡氨鏄牴鎹畇heet绱㈠紩鑾峰彇sheet鍐呭銆7銆佹渶鍚庡氨鏄鍙栦竴涓...
  • 鏂版墜瀛︿範Python,姹傛暀Python涓浣曞鍏excel鏁版嵁
    绛旓細璇excel瑕佺敤鍒皒lrd妯″潡锛屽畼缃戝畨瑁咃紙http://pypi.python.org/pypi/xlrd锛夈傜劧鍚庡氨鍙互璺熺潃閲岄潰鐨勪緥瀛愮◢寰瘯涓涓嬪氨鐭ラ亾鎬庝箞鐢ㄤ簡銆傚ぇ姒傜殑娴佺▼鏄繖鏍风殑锛1銆佸鍏ユā鍧 import xlrd 2銆佹墦寮Excel鏂囦欢璇诲彇鏁版嵁 data = xlrd.open_workbook('excel.xls')3銆佽幏鍙栦竴涓伐浣滆〃 鈶 table = data.sheets()[0] ...
  • 鎬庢牱鐢python,璇诲彇excel涓殑涓鍒楁暟鎹
    绛旓細data=pd.read_excel('F:/data.xlsx', sheet_name='Sheet1')print(type(data))print(data)print(data['B'])#璇诲彇鏌愪竴鍒 print(data.values)#杈撳嚭鍊 print(data.describe())#杈撳嚭姣忓垪鐨勭粺璁℃暟鎹 x=data[0:10]print(x)#杈撳嚭鍓3琛 print(x.T)#杞疆 print(x.sort_index(axis=1,ascending...
  • python涓璇诲彇excel鏂囦欢
    绛旓細sheet=data.sheet_by_name('Sheet1')#鑾峰緱绗竴涓伐浣滆〃 sheet=book.sheets()[0]#鑾峰緱绗竴涓伐浣滆〃 鑾峰彇鎬昏鏁 nrows = table.nrows 鑾峰彇鎬诲垪鏁 ncols = table.ncols 宸ヤ綔琛ㄧ殑鏁扮洰 book.nsheets sheet.cell(0,1)sheet.row(0)璇诲彇绗簩鍒楃殑鍐呭锛屼粠绗簩琛屽紑濮嬶紝骞跺鍏舵眰鍜 sum...
  • 鎬庝箞鐢Python璇诲彇excel涓叕寮忕殑缁撴灉
    绛旓細鐢╫penpyxl妯″潡璇诲彇excel涓殑鍏紡缁撴灉銆備唬鐮佸涓:import openpyxlwb= openpyxl.load_workbook('sogou.xlsx',data_only=True)
  • Python涓殑pandas濡備綍璇诲彇excel涓寚瀹氬崟鍏冩牸鐨勫?
    绛旓細pandas 璇诲彇鎸囧畾鍗曞厓鏍 绗2琛岋紝绗3鍒 import pandas as pd df = pd.read_excel('娴嬭瘯.xlsx')cell = df.iat[0, 2][0, 2] 琛ㄧず鍗曞厓鏍肩殑琛屽垪 pandas 榛樿璺宠繃琛ㄥご浠庣浜岃寮濮 绗笁鍒楁槸2 (012)
  • python涓敤openpyxl璇诲彇excel琛ㄦ牸鏁版嵁,骞朵笖杞崲鎴愬瓧鍏告牸寮
    绛旓細璇诲彇excel涓殑鏁版嵁 绗竴姝ユ墦寮宸ヤ綔绨 wb = openpyxl.load_workbook('cases.xlsx')绗簩姝ラ夊彇琛ㄥ崟,娉ㄦ剰Sheet鏄ぇ鍐欑殑S sheet = wb['Sheet1']鎸夎鑾峰彇鏁版嵁杞崲鎴愬垪琛 鍏堝畾涔変竴涓荤殑鍒楄〃鎵鏈夌殑琛屽厛鏀惧湪鍒楄〃涓 rows_data = list(sheet.rows)鑾峰彇琛ㄥ崟鐨勮〃澶翠俊鎭(绗竴琛)锛屼篃灏辨槸鍒楄〃鐨勭涓涓厓绱 ...
  • 扩展阅读:学python后到底能干什么 ... python手机在线编程入口 ... python手机版下载官方 ... python怎么读正确发音 ... python解释器手机版下载 ... python怎么读取excel文件 ... python初学编程必背 ... python登录网站 ... python教程 ...

    本站交流只代表网友个人观点,与本站立场无关
    欢迎反馈与建议,请联系电邮
    2024© 车视网