基于DataFrame改變列類型的方法
今天用numpy 的linalg.det()求矩陣的逆的過程中出現(xiàn)了一個錯誤:
TypeError: No loop matching the specified signature and casting was found for ufunc det
查了半天發(fā)現(xiàn)是數(shù)據(jù)類型的問題,numpy在算逆的時候會先檢查一下數(shù)據(jù)類型是否一致,若不一致就會報錯(話說這個錯誤提示信息也太難理解了,還得看源碼o(╯□╰)o)。
由于我的數(shù)據(jù)是用pandas.DataFrame讀取的,所以每一列的數(shù)據(jù)類型有可能不同。
回頭檢查一下數(shù)據(jù),果然有的是int,有的是float。所以全部改為float64類型。
找到了如下的方法,以及DataFrame數(shù)據(jù)類型:
DataFrame 類型轉換方法—astype()
import pandas as pd df = pd.DataFrame([{'col1':'a', 'col2':'1'}, {'col1':'b', 'col2':'2'}]) print df.dtypes df['col2'] = df['col2'].astype('int') print '-----------' print df.dtypes df['col2'] = df['col2'].astype('float64') print '-----------' print df.dtypes
輸出:
col1 object col2 object dtype: object ----------- col1 object col2 int32 dtype: object ----------- col1 object col2 float64 dtype: object
astype()也能一次改變所有數(shù)據(jù)的類型:
In[30]:a Out[31]: a b c d 0 0.891380 0.442167 -0.539450 1.023458 1 -0.488131 -1.847104 -0.209799 -0.768713 2 1.290434 0.327096 0.358406 0.422209 In[32]:a.astype('int32') Out[32]: a b c d 0 0 0 0 1 1 0 -1 0 0 2 1 0 0 0
附:data type list
Data type Description bool_ Boolean (True or False) stored as a byte int_ Default integer type (same as C long; normally either int64 or int32) intc Identical to C int (normally int32 or int64) intp Integer used for indexing (same as C ssize_t; normally either int32 or int64) int8 Byte (-128 to 127) int16 Integer (-32768 to 32767) int32 Integer (-2147483648 to 2147483647) int64 Integer (-9223372036854775808 to 9223372036854775807) uint8 Unsigned integer (0 to 255) uint16 Unsigned integer (0 to 65535) uint32 Unsigned integer (0 to 4294967295) uint64 Unsigned integer (0 to 18446744073709551615) float_ Shorthand for float64. float16 Half precision float: sign bit, 5 bits exponent, 10 bits mantissa float32 Single precision float: sign bit, 8 bits exponent, 23 bits mantissa float64 Double precision float: sign bit, 11 bits exponent, 52 bits mantissa complex_ Shorthand for complex128. complex64 Complex number, represented by two 32-bit floats (real and imaginary components) complex128 Complex number, represented by two 64-bit floats (real and imaginary components)
以上這篇基于DataFrame改變列類型的方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Pandas?Groupby之在Python中匯總、聚合和分組數(shù)據(jù)的示例詳解
GroupBy是一個非常簡單的概念,我們可以創(chuàng)建一個類別分組,并對這些類別應用一個函數(shù),本文給大家介紹Pandas?Groupby之如何在Python中匯總、聚合和分組數(shù)據(jù),感興趣的朋友跟隨小編一起看看吧2023-07-07如何在Windows環(huán)境下安裝PyMySQL(已安裝Anaconda)
這篇文章主要介紹了如何在Windows環(huán)境下安裝PyMySQL問題(已安裝Anaconda),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-08-08計算機二級python學習教程(3) python語言基本數(shù)據(jù)類型
這篇文章主要為大家詳細介紹了計算機二級python學習教程的第3篇,python語言基本數(shù)據(jù)類型,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-05-05Python中使用第三方庫xlutils來追加寫入Excel文件示例
這篇文章主要介紹了Python中使用第三方庫xlutils來追加寫入Excel文件示例,本文直接給出追加寫入示例和追加效果,需要的朋友可以參考下2015-04-04