日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無先后,達(dá)者為師

網(wǎng)站首頁 編程語言 正文

python數(shù)據(jù)分析之如何刪除value=0的行_python

作者:小白只對大佬的文章感興趣 ? 更新時(shí)間: 2023-01-09 編程語言

前言

拿到一堆數(shù)據(jù),首先我們是要對其進(jìn)行數(shù)據(jù)的預(yù)處理,其中數(shù)據(jù)存在一些值為空或者是我們不想要的數(shù)據(jù),對其進(jìn)行刪除或者是修改數(shù)據(jù)值。下面是對于該例子進(jìn)行刪除和修改:

>>> df
out[]:
   salary   age   gender
0   10000    23     男
1   15000    34     女
2   23000    21     男
3     0      20     女
4   28500     0     男
5   35000    37     男

一、數(shù)據(jù)處理

1. df.replace()方法:將“男”用1來表示,“女孩”用0來表示。

>>> df.replace(["男", "女"], [1, 0])
out[]:
   salary   age   gender
0   10000    23     1
1   15000    34     0
2   23000    21     1
3     0      20     0
4   28500     0     1
5   35000    37     1

2.??pd.DataFrame.loc()方法來指定列中數(shù)據(jù)為0的行:

>>> df = df.loc[~((df['salary'] == 0) | (df['age'] == 0))]
>>> df
out[]:
   salary   age   gender
0   10000    23     1
1   15000    34     0
2   23000    21     1
3   35000    37     1

還可以用:?

df = df.loc[df['salary'] * df['age'] != 0]

二、刪除某行方法的使用

1.刪除全行都是為0的行

代碼如下:

>>> df.loc[~(df==0).all(axis=1)]

?看起來比較對稱可以這樣寫:

>>> df.loc[(df!=0).any(axis=1)]

使用dropna方法來刪除:

>>> new_df = df[df.loc[:]!=0].dropna()

2.用nan替換零,然后刪除所有行中數(shù)據(jù)都為nan的行。之后,將nan替換為零。

代碼如下:

import numpy as np
df = df.replace(0, np.nan)# 把0替換成nan
df = df.dropna(how='all', axis=0)# 刪除所有為nan的行
df = df.replace(np.nan, 0)# 再把nan替換成0

3.刪除某行中某個(gè)值為0的行

代碼如下:|

>>> df= df[df['salary'] != 0]

4.使用lambda函數(shù)來刪除行

代碼如下:

import pandas as pd
import numpy as np
 
np.random.seed(0)
 
df = pd.DataFrame(np.random.randn(5,3),
                  index=['one', 'two', 'three', 'four', 'five'],
                  columns=list('abc'))
 
df.loc[['one', 'three']] = 0 # 把第一行和第三行改為0
 
print(df)
print(df.loc[~df.apply(lambda row: (row==0).all(), axis=1)])

輸出為:

要在任何行中刪除所有值為0的列:?

new_df = df[df.loc[:]!=0].dropna()
new_df

?輸出為:

總結(jié)

原文鏈接:https://blog.csdn.net/ex_6450/article/details/126867123

欄目分類
最近更新