想请教一个 pandas 数据处理的问题:

2018-01-21 09:25:00 +08:00
 Kaguyahime
import os
import pandas as pd
import glob

def hebing():
csv_list = glob.glob("D:\\pythonNotebook\\SH\\SH_CSV\\*.csv")
print(u'共发现%s 个 CSV 文件'% len(csv_list))
print(u'正在处理............')
for i in csv_list:
fr = open(i,'r').read()
df = pd.read_csv(i,header=None,sep=',',usecols=range(0,8))
IsDuplicated = df.duplicated()
df = df.drop_duplicates()
#LAT = df.iloc[:,6]
#df.insert(8,'N','N')
#for j in range(0,len(LAT)):
#str(LAT[j])
#df['N'][j] = LAT[j][-1] #SH 区全部是南纬的
#LAT[j].replace('N','')
#LAT[j].replace('S','')
#print(LAT[j])
#print(i)
#df['Lat'] = df['Lat'].astype(np.float64)
#data = df.pop('Lat')
#data = -data/10 #南纬
#df.insert(8,'Lat',data)

if __name__ == '__main__':
hebing()

有问题的是我注释掉的部分。
我想做的事情,是把一列 str 格式的数据全部按宽度分列,原来第 6 列的数据是“ 118S ”的形式(南纬 118°),我需要把它分成 118、S 两列进行计算。我的想法是把它的最后一个字符‘ S ’提取出来赋给新的一列,然后删去原来那一列中的最后一个字符。
遇到了两个问题,一是,replace 之后并没有能删除掉原来数据中的‘ N、S ’字符;
二是每次读到第四十几个文件就报错了(一共 1000 多个);

pandas 入门级小白,求解答。

如果有什么可以直接按宽度分列的代码(类似于 excel 的功能)就更好啦
981 次点击
所在节点    问与答
1 条回复
princelai
2018-01-21 10:11:46 +08:00
pandas.Series.str.slice

pandas.Series.str.extract

想用哪个用哪个,至于报错,你可以 LAT.apply(),自己写个 lambda 函数,里面 try 一下就可以知道哪里出错了或者出错值置为 none

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/424623

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX