【python小白】日常工作中的幾個TIPS(二)

pandas直接讀取文件相當方便,但是剛接觸時浆兰,DataFrame型的行列選擇極易讓人混亂磕仅,常與array型的選取混淆∧魉希總結一下兩種結構不同的行列操作宽涌。

# 首先弄點數(shù)據(jù)
import numpy as np
import pandas as pd
a = np.random.randn(3,4)
a = pd.DataFrame(a)
a.columns=['A','B','簡','書']
b = np.array(a)

a
Out: 
          A         B         簡         書
0 -0.111949  0.527505  2.368722  1.224539
1  0.682014  1.437826  0.004001 -0.330349
2  0.716501 -1.719973  0.718745  2.023330

b
Out: 
array([[-0.11194892,  0.5275052 ,  2.36872241,  1.22453866],
       [ 0.68201417,  1.43782573,  0.00400142, -0.33034887],
       [ 0.7165014 , -1.71997254,  0.71874518,  2.02332967]])

行選擇

DataFrame

可以使用loc[]平夜,iloc[]蝶棋,ix[]來選擇。

# 連續(xù)選擇忽妒,注意括號里的包含關系
a.loc[1:3]
Out: 
          A         B         簡         書
1  0.682014  1.437826  0.004001 -0.330349
2  0.716501 -1.719973  0.718745  2.023330

# 選擇單行
a.loc[[1,2]]
Out: 
          A         B         簡         書
1  0.682014  1.437826  0.004001 -0.330349
2  0.716501 -1.719973  0.718745  2.023330

# 選擇某個數(shù)據(jù)
a.ix[[1],[1]]
Out: 
          B
1  1.437826

array

相比之下玩裙,矩陣的操作則要方便許多。

# 連續(xù)選擇
b[1:3]
Out: 
array([[ 0.68201417,  1.43782573,  0.00400142, -0.33034887],
       [ 0.7165014 , -1.71997254,  0.71874518,  2.02332967]])

# 選擇單行
b[[1,2]]
Out: 
array([[ 0.68201417,  1.43782573,  0.00400142, -0.33034887],
       [ 0.7165014 , -1.71997254,  0.71874518,  2.02332967]])

# 某個數(shù)據(jù)選擇
b[1,1]
Out: 1.4378257322265775

列選擇

DataFrame

較之行選擇段直,DataFrame格式的列選擇要簡單些吃溅,中英文的column都可以直接通過列名選取。

# 通過列名
a.A
Out: 
0   -0.111949
1    0.682014
2    0.716501
Name: A, dtype: float64

a[['B','書']]
Out: 
          B         書
0  0.527505  1.224539
1  1.437826 -0.330349
2 -1.719973  2.023330

有時候column的名稱復雜鸯檬,經(jīng)常要切換輸入法决侈,很不方便,或者想選擇很多列時喧务,可以通過索引來進行選取赖歌。pandas這里有個小坑枉圃,連續(xù)列直接用a[1:3]會報錯 =='

# 通過索引號,連續(xù)列選擇
a[np.arange(1,3)]
Out: 
          B         簡
0  0.527505  2.368722
1  1.437826  0.004001
2 -1.719973  0.718745

# 通過索引號庐冯,選擇特定列
a[[1,3]]
Out: 
          B         書
0  0.527505  1.224539
1  1.437826 -0.330349
2 -1.719973  2.023330

array

感受下數(shù)值處理時矩陣的簡捷直觀孽亲。

b[:,[1,3]]
Out: 
array([[ 0.5275052 ,  1.22453866],
       [ 1.43782573, -0.33034887],
       [-1.71997254,  2.02332967]])

b[[1,2],[1,2]]
Out: array([ 1.43782573,  0.71874518])

補充下openpyxl打開xlsx文件下數(shù)據(jù)的選取。

import openpyxl
wb = openpyxl.load_workbook('file path')
sheets = wb.get_sheet_names()
sheet1 = wb.get_sheet_by_name(sheets[0])
sheet1['B1'].value    # 通過單元格索引打開
sheet1.cell(row=1, column=1).value    # 通過行列號

兩種結構可以方便的相互轉(zhuǎn)換展父,pd.DataFrame()返劲,np.array()【或者np.asarray(),兩者有略微的差別】栖茉。挑一種順手的套路吧篮绿!

TBC

?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市吕漂,隨后出現(xiàn)的幾起案子搔耕,更是在濱河造成了極大的恐慌,老刑警劉巖痰娱,帶你破解...
    沈念sama閱讀 217,826評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件弃榨,死亡現(xiàn)場離奇詭異,居然都是意外死亡梨睁,警方通過查閱死者的電腦和手機鲸睛,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,968評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來坡贺,“玉大人官辈,你說我怎么就攤上這事”榉兀” “怎么了拳亿?”我有些...
    開封第一講書人閱讀 164,234評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長愿伴。 經(jīng)常有香客問我肺魁,道長,這世上最難降的妖魔是什么隔节? 我笑而不...
    開封第一講書人閱讀 58,562評論 1 293
  • 正文 為了忘掉前任鹅经,我火速辦了婚禮,結果婚禮上怎诫,老公的妹妹穿的比我還像新娘瘾晃。我一直安慰自己,他們只是感情好幻妓,可當我...
    茶點故事閱讀 67,611評論 6 392
  • 文/花漫 我一把揭開白布蹦误。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪强胰。 梳的紋絲不亂的頭發(fā)上尚镰,一...
    開封第一講書人閱讀 51,482評論 1 302
  • 那天,我揣著相機與錄音哪廓,去河邊找鬼狗唉。 笑死,一個胖子當著我的面吹牛涡真,可吹牛的內(nèi)容都是我干的分俯。 我是一名探鬼主播,決...
    沈念sama閱讀 40,271評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼哆料,長吁一口氣:“原來是場噩夢啊……” “哼缸剪!你這毒婦竟也來了?” 一聲冷哼從身側響起东亦,我...
    開封第一講書人閱讀 39,166評論 0 276
  • 序言:老撾萬榮一對情侶失蹤杏节,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后典阵,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體奋渔,經(jīng)...
    沈念sama閱讀 45,608評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,814評論 3 336
  • 正文 我和宋清朗相戀三年壮啊,在試婚紗的時候發(fā)現(xiàn)自己被綠了嫉鲸。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,926評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡歹啼,死狀恐怖玄渗,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情狸眼,我是刑警寧澤藤树,帶...
    沈念sama閱讀 35,644評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站拓萌,受9級特大地震影響岁钓,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜司志,卻給世界環(huán)境...
    茶點故事閱讀 41,249評論 3 329
  • 文/蒙蒙 一甜紫、第九天 我趴在偏房一處隱蔽的房頂上張望降宅。 院中可真熱鬧骂远,春花似錦、人聲如沸腰根。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,866評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至瘸恼,卻和暖如春劣挫,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背东帅。 一陣腳步聲響...
    開封第一講書人閱讀 32,991評論 1 269
  • 我被黑心中介騙來泰國打工压固, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人靠闭。 一個月前我還...
    沈念sama閱讀 48,063評論 3 370
  • 正文 我出身青樓帐我,卻偏偏與公主長得像,于是被迫代替她去往敵國和親愧膀。 傳聞我的和親對象是個殘疾皇子拦键,可洞房花燭夜當晚...
    茶點故事閱讀 44,871評論 2 354

推薦閱讀更多精彩內(nèi)容