一、常用方法
通過str訪問,且自動排除丟失/ NA值
s = pd.Series(['A','b','C','bbhello','123',np.nan,'hj'])
df = pd.DataFrame({'key1':list('abcdef'),
'key2':['hee','fv','w','hija','123',np.nan]})
# 直接通過.str調用字符串方法
# 可以對Series、Dataframe使用
# 自動過濾NaN值
print(s.str.count('b'), '計數\'b\'出現的次數')
print(s.str.lower(),'→ lower小寫\n')
print(s.str.upper(),'→ upper大寫\n')
print(s.str.len(),'→ len字符長度\n')
print(s.str.startswith('b'),'→ 判斷起始是否爲a\n')
print(s.str.endswith('3'),'→ 判斷結束是否爲3\n')
print(s.str.capitalize(),'→ 首字母大寫\n')
print(df['key2'].str.upper(),'→ 用法和Series一樣\n')
# df.columns(列標籤名)是一個Index對象,也可使用.str
df.columns = df.columns.str.upper()
print(df)
二、去掉空格strip
s = pd.Series([' jack', 'jill ', ' jesse ', 'frank'])
df = pd.DataFrame(np.random.randn(3, 2), columns=[' Column A ', ' Column B '],
index=range(3))
print(s)
print(df)
print('-----')
print(s.str.strip()) # 去除字符串中的空格
print(s.str.lstrip()) # 去除字符串中的左空格
print(s.str.rstrip()) # 去除字符串中的右空格
df.columns = df.columns.str.strip()
print(df)
# 這裏去掉了columns的前後空格,但沒有去掉中間空格
三、替換replace
df = pd.DataFrame(np.random.randn(3, 2), columns=[' Column A ', ' Column B '],
index=range(3))
df.columns = df.columns.str.replace(' ','-')
print(df)
# 替換
df.columns = df.columns.str.replace('-','hehe',n=1)
print(df)
# n:替換個數
四、拆分split、rsplit
# 類似字符串的split
s = pd.Series(['a,b,c','1,2,3',['a,,,c'],np.nan])
print(s.str.split(','))
print('-----')
# 直接索引得到一個list,數字0是index的名字
print(s.str.split(',')[0])
print('-----')
# 可以使用get或[]符號訪問拆分列表中的str的元素
print(s.str.split(',').str[0])
print(s.str.split(',').str.get(1))
print('-----')
# 可以使用expand可以輕鬆擴展此操作以返回DataFrame
print(s.str.split(',', expand=True))
print(s.str.split(',', expand=True, n = 1))# n參數限制分割數
print(s.str.rsplit(',', expand=True, n = 1))
print('-----')
# rsplit類似於split,反向工作,即從字符串的末尾到字符串的開頭
df = pd.DataFrame({'key1':['a,b,c','1,2,3',[':,., ']],
'key2':['a-b-c','1-2-3',[':-.- ']]})
print(df['key2'].str.split('-'))
# Dataframe使用split
五、字符串索引
s = pd.Series(['A','b','C','bbhello','123',np.nan,'hj'])
df = pd.DataFrame({'key1':list('abcdef'),
'key2':['hee','fv','w','hija','123',np.nan]})
# str之後和字符串本身索引方式相同
print(s.str[0]) # 取第一個字符串
print(s.str[:2]) # 取前兩個字符串
print(df['key2'].str[0])
打賞
碼字不易,如果對您有幫助,就打賞一下吧O(∩_∩)O