跳到主要內容

[python] pandas Series 超快速值域轉換!

最近 hahow 通知 Python 資料分析&機械學習入門 開課了!

所以無所事事的無職男決定重拾一下寫 code 的樂趣

前面都順順的講解一下各式大神/關鍵字/資料庫來源/參考來源等等。

說真的光是這些東西就真的很值得。


只要知道關鍵字,就算是神我也肉搜給你看 -by me


在重複看了一次的 jupyter notebook 與 pandas 簡單教學之後,

開始正式處理資料分析: 鳶尾花 Iris 的分析。


意外的簡單地抓取資料來結合,然後其中一行就吸引到我了:


y1 = pd.DataFrame(pd.Series(iris['target']).map(dict(enumerate(iris['target_names']))),columns= ["target_names"])





哇靠這一行是在寫什麼東西,太長太可怕了吧!

仔細看了拆拆解解,才發現原來之前忙了很久的值參照轉換這麼簡單就完成了,讚讚!


首先是


enumerate() 代表會創造一個疊代子,依序傳出 list 的物件的 (index, value)

list =  ["A", "B", "C"]

for i, j in enumerate(list):

    print i, j

#output

#0,A

#1,B

#2,C


如果神秘的包在 dict() 裡面,就會自動創造一個 key, value 配對,超強!

dd = dict(enumerate(list))

print(dd)



#output

#{0:"A", 1:"B", 2:"C"}



另外一個好用的是 .map()

他可以使用 dict() 做 pd.Series 的 值取代

所以

list1 =pd.Series([0,0,0,1,1,2])

print(list1.map({0:"A", 1:"B", 2:"C"}))


#output

#0    A
#1    A
#2    A
#3    B
#4    B
#5    C


可以看到使用 map 可以直接把 0 用 dict() 的 value 取代

真的好用!

留言

這個網誌中的熱門文章

[python] 使用 python 控制 docx 範例

因為同事的需求,無職 a 我就又再度幫忙同事寫一些小程式。 這些小程式雖然簡單,但是聽到如果不幫忙寫程式解決,以手工作業的"大量人天" 的後果真的是讓人吐血。 他們有一份工作,需要產出一份很多很多很多資料圖片的判釋報告,要把數百張圖片剪裁成特定大小,加上圖說之後放入 word 裡面。 聽到的做法是...一張一張插圖!! wooow! That's really shocking me! 所以為了前公司同事的幸福,我還是加減寫一下好了。

[電銲] 自己的 IMU 自己焊!笨蛋的焊接法!

工程師真的是被要求包山包海都要會... IMU的組件被要求不能只插麵包板,要 "穩固的固定在另外製作的盒子裡",反正就是搞得跟外面幾十萬上下的 IMU 一樣精緻就是了。 好好好都焊給你~ 呃 對了 怎麼焊哈哈哈哈 ^^" 電焊這種技術自從上過國中的生活科技後就再也沒再用了@@,好家在這是個網路就是你家的時代,立刻上網查一查,找到一些關於焊槍使用的相關資料。 被要求說GY-91不能只接麵包板一定焊死才穩固所以就這樣接了

[RaspberryPI] 一鍵啟動 .py 文件

先講總結: 樹莓派君你好討厭啊啊啊啊! 今天把程式整理完之後,心血來潮,想要把 程式弄得更 "一鍵啟動" 一點。 也就是我只要用我的觸控螢幕一點,就可以直接打開寫好的 QT 介面做 IMU 和 相機的紀錄 親手烘培(?) 的 QT 介面