pandas 數(shù)據(jù)歸一化以及行刪除例程的方法
更新時(shí)間:2018年11月10日 10:46:05 作者:夜月xl
今天小編就為大家分享一篇pandas 數(shù)據(jù)歸一化以及行刪除例程的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
如下所示:
#coding:utf8 import pandas as pd import numpy as np from pandas import Series,DataFrame # 如果有id列,則需先刪除id列再進(jìn)行對(duì)應(yīng)操作,最后再補(bǔ)上 # 統(tǒng)計(jì)的時(shí)候不需要用到id列,刪除的時(shí)候需要考慮 # delete row def row_del(df, num_percent, label_len = 0): #print list(df.count(axis=1)) col_num = len(list(list(df.values)[1])) - label_len # -1為考慮帶標(biāo)簽 if col_num<0: print 'Error' #print int(col_num*num_percent) return df.dropna(axis=0, how='any', thresh=int(col_num*num_percent)) # 如果有字符串類型,則報(bào)錯(cuò) # data normalization -1 to 1 # label_col: 不需考慮的類標(biāo),可以為字符串或字符串列表 # 數(shù)值類型統(tǒng)一到float64 def data_normalization(df, label_col = []): lab_len = len(label_col) print label_col if lab_len>0: df_temp = df.drop(label_col, axis = 1) df_lab = df[label_col] print df_lab else: df_temp = df max_val = list(df_temp.max(axis=0)) min_val = list(df_temp.min(axis=0)) mean_val = list((df_temp.max(axis=0) + df_temp.min(axis=0)) / 2) nan_values = df_temp.isnull().values row_num = len(list(df_temp.values)) col_num = len(list(df_temp.values)[1]) for rn in range(row_num): #data_values_r = list(data_values[rn]) nan_values_r = list(nan_values[rn]) for cn in range(col_num): if nan_values_r[cn] == False: df_temp.values[rn][cn] = 2 * (df_temp.values[rn][cn] - mean_val[cn])/(max_val[cn] - min_val[cn]) else: print 'Wrong' for index,lab in enumerate(label_col): df_temp.insert(index, lab, df_lab[lab]) return df_temp # 創(chuàng)建一個(gè)帶有缺失值的數(shù)據(jù)框: df = pd.DataFrame(np.random.randn(5,3), index=list('abcde'), columns=['one','two','three']) df.ix[1,:-1]=np.nan df.ix[1:-1,2]=np.nan df.ix[0,0]=int(1) df.ix[2,2]='abc' # 查看一下數(shù)據(jù)內(nèi)容: print '\ndf1' print df print row_del(df, 0.8) print '-------------------------' df = data_normalization(df, ['two', 'three']) print df print df.dtypes print (type(df.ix[2,2]))
以上這篇pandas 數(shù)據(jù)歸一化以及行刪除例程的方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python實(shí)現(xiàn)報(bào)警信息實(shí)時(shí)發(fā)送至郵箱功能(實(shí)例代碼)
這篇文章主要介紹了Python實(shí)現(xiàn)報(bào)警信息實(shí)時(shí)發(fā)送至郵箱,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-11-11Python實(shí)現(xiàn)子類調(diào)用父類的初始化實(shí)例
這篇文章主要介紹了Python實(shí)現(xiàn)子類調(diào)用父類的初始化實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-03-03Python實(shí)現(xiàn)的簡單模板引擎功能示例
這篇文章主要介紹了Python實(shí)現(xiàn)的簡單模板引擎功能,結(jié)合具體實(shí)例形式分析了Python模版引擎的定義與使用方法,需要的朋友可以參考下2017-09-09基于python和flask實(shí)現(xiàn)http接口過程解析
這篇文章主要介紹了基于python和flask實(shí)現(xiàn)http接口過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06python報(bào)錯(cuò): ''list'' object has no attribute ''shape''的解決
這篇文章主要介紹了python報(bào)錯(cuò): 'list' object has no attribute 'shape'的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-07-07