根据条件删除 DataFrame 中的元素
Delete element in DataFrame under condition
我的 DataFrame 正在查看这个:
indeed.fr
11.41%
career2.successfactors.eu
8.53%
37.16%
pracuj.pl
7.40%
80.42%
corporate.danone.com.br
6.64%
indeed.com.br
4.68%
61.73%
因此我只想保留前 % 如下:
indeed.fr
11.41%
career2.successfactors.eu
8.53%
pracuj.pl
7.40%
corporate.danone.com.br
6.64%
indeed.com.br
4.68%
所有的行都是字符串等等不知道是否可以在上一行包含%这样的情况下删除行?
有什么想法吗?
感谢您的宝贵时间!
mydata =['indeed.fr','11.41%','career2.successfactors.eu','8.53%','37.16%','pracuj.pl','7.40%','80.42%','corporate.danone.com.br','6.64%','indeed.com.br','4.68%','61.73%']
df=pd.DataFrame(mydata)
最后,我想要这个:
mydata =['indeed.fr','11.41%','career2.successfactors.eu','8.53%','37.16%','pracuj.pl','7.40%','80.42%','corporate.danone.com.br','6.64%','indeed.com.br','4.68%','61.73%']
df = pd.DataFrame(mydata)
是您创建的示例。
解决方法如下
rowList = []
row = []
#Variable to keep track of the number of times I see the percentage value
percentVal = 0
for i in df.index:
if(df.at[i, 0][0] not in set('0123456789')):
row.append(df.at[i, 0])
percentVal = 0
else:
percentVal += 1
if(percentVal != 2):
row.append(df.at[i, 0])
rowList.append(row)
row = []
else:
#If percentVal == 2, that means, I have seen my second percentage value and I'm going to skip it.
print("Skipping {}".format(df.at[i, 0]))
row = []
yourSol = pd.DataFrame(rowList)
yourSol.columns = ['Incoming Referal Sources', 'Value (%)']
print(yourSol)
我的 DataFrame 正在查看这个:
indeed.fr
11.41%
career2.successfactors.eu
8.53%
37.16%
pracuj.pl
7.40%
80.42%
corporate.danone.com.br
6.64%
indeed.com.br
4.68%
61.73%
因此我只想保留前 % 如下:
indeed.fr
11.41%
career2.successfactors.eu
8.53%
pracuj.pl
7.40%
corporate.danone.com.br
6.64%
indeed.com.br
4.68%
所有的行都是字符串等等不知道是否可以在上一行包含%这样的情况下删除行?
有什么想法吗?
感谢您的宝贵时间!
mydata =['indeed.fr','11.41%','career2.successfactors.eu','8.53%','37.16%','pracuj.pl','7.40%','80.42%','corporate.danone.com.br','6.64%','indeed.com.br','4.68%','61.73%']
df=pd.DataFrame(mydata)
最后,我想要这个:
mydata =['indeed.fr','11.41%','career2.successfactors.eu','8.53%','37.16%','pracuj.pl','7.40%','80.42%','corporate.danone.com.br','6.64%','indeed.com.br','4.68%','61.73%']
df = pd.DataFrame(mydata)
是您创建的示例。
解决方法如下
rowList = []
row = []
#Variable to keep track of the number of times I see the percentage value
percentVal = 0
for i in df.index:
if(df.at[i, 0][0] not in set('0123456789')):
row.append(df.at[i, 0])
percentVal = 0
else:
percentVal += 1
if(percentVal != 2):
row.append(df.at[i, 0])
rowList.append(row)
row = []
else:
#If percentVal == 2, that means, I have seen my second percentage value and I'm going to skip it.
print("Skipping {}".format(df.at[i, 0]))
row = []
yourSol = pd.DataFrame(rowList)
yourSol.columns = ['Incoming Referal Sources', 'Value (%)']
print(yourSol)