![](/img/trans.png)
[英]Pandas slice string based on str.find as position to start and stop
[英]using pandas str.find method to slice strings in dataframe column
我有一個數據幀列,看起來像這樣:
s = pd.Series(["a0a1a3", "b1b3", "c1c1c3c3"], index=["A", "B", "C"])
我可以找到str.find方法在每個單元格中找到我想要的indeces:
s.str.find('1').values
array([3, 1, 1])
s.str.find('3').values
array([5, 3, 5])
但是我找不到如何使用這些函數來剪切該列中的字符串。 例如:
s.str[s.str.find('1').values:s.str.find('3').values].values
給
array([ nan, nan, nan])
哪種結合這些功能的正確方法?
那是你要的嗎?
In [87]: s.str.split('1').str[0]
Out[87]:
A a
B b
C c
dtype: object
In [88]: s.str.split('1').str[1]
Out[88]:
A a2
B b2
C c2
dtype: object
要么
In [89]: s.str.split('1', expand=True)
Out[89]:
0 1
A a a2
B b b2
C c c2
您將在官方Pandas docs網站上找到許多有用的示例
更新:
In [203]: s = pd.Series(["a1a2", "b1b2", "c1c2", "aaaaaa1XX"], index=["A", "B", "C", "D"])
In [204]: s
Out[204]:
A a1a2
B b1b2
C c1c2
D aaaaaa1XX
dtype: object
In [205]: s.str.split('1', expand=True)
Out[205]:
0 1
A a a2
B b b2
C c c2
D aaaaaa XX
UPDATE2:
In [224]: s
Out[224]:
A a0a1a3
B b1b3
C c1c1c3c3
dtype: object
In [225]: s.str.extract(r'1(.*?)3', expand=False)
Out[225]:
A a
B b
C c1c
dtype: object
注:請務必發布源代碼和所需數據集-否則,我們不得不猜測什么是你想實現...
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.