NumPy(五): 字符串函数

以下函数用于对 dtype 为 numpy.string_ 或 numpy.unicode_ 的数组执行向量化字符串操作。 它们基于 Python 内置库中的标准字符串函数。

这些函数在字符数组类(numpy.char)中定义。

函数 描述
add() 对两个数组的逐个字符串元素进行连接
multiply() 返回按元素多重连接后的字符串
center() 居中字符串
capitalize() 将字符串第一个字母转换为大写
title() 将字符串的每个单词的第一个字母转换为大写
lower() 数组元素转换为小写
upper() 数组元素转换为大写
split() 指定分隔符对字符串进行分割,并返回数组列表
splitlines() 返回元素中的行列表,以换行符分割
strip() 移除元素开头或者结尾处的特定字符
join() 通过指定分隔符来连接数组中的元素
replace() 使用新字符串替换字符串中的所有子字符串
decode() 数组元素依次调用str.decode
encode() 数组元素依次调用str.encode

numpy.char.add() 函数依次对两个数组的元素进行字符串连接。

>>> print (np.char.add(['hello'],[' xyz']))
['hello xyz']
>>> print (np.char.add(['hello', 'hi'],[' abc', ' xyz']))
['hello abc' 'hi xyz']

>>> a = np.array(['hello', 'hi'])
>>> b = np.array([' abc', ' xyz'])
>>> a
array(['hello', 'hi'], dtype='<U5')
>>> b
array([' abc', ' xyz'], dtype='<U4')
>>> print (np.char.add(a,b))
['hello abc' 'hi xyz']

numpy.char.multiply() 函数执行多重连接。

>>> print (np.char.multiply('Good Luck  ',3))
Good Luck  Good Luck  Good Luck  

numpy.char.center() 函数用于将字符串居中,并使用指定字符在左侧和右侧进行填充。

>>> print (np.char.center('Good', 20,fillchar = '*'))
********Good********

numpy.char.capitalize() 函数将字符串的第一个字母转换为大写:

>>> print (np.char.capitalize('good'))
Good

numpy.char.title() 函数将字符串的每个单词的第一个字母转换为大写:

>>> print (np.char.title('good good study,day day up'))
Good Good Study,Day Day Up

numpy.char.lower() 函数对数组的每个元素转换为小写。它对每个元素调用 str.lower。

>>> print (np.char.lower(['GOOD','LUCK']))
['good' 'luck']

numpy.char.upper() 函数对数组的每个元素转换为大写。它对每个元素调用 str.upper。

>>> print (np.char.upper ('i like tokyo hot?'))
I LIKE TOKYO HOT?

numpy.char.split() 通过指定分隔符对字符串进行分割,并返回数组。默认情况下,分隔符为空格。

>>> print (np.char.split ('i like tokyo hot?'))
['i', 'like', 'tokyo', 'hot?']
#设定分隔符
>>> print (np.char.split ('www.tokyohot.com', sep = '.'))
['www', 'tokyohot', 'com'] 

numpy.char.splitlines() 函数以换行符作为分隔符来分割字符串,并返回数组。

>>> print (np.char.splitlines('i\nlike xiaozemaliya?'))
['i', 'like xiaozemaliya?']

\n,\r,\r\n 都可用作换行符。

numpy.char.strip() 函数用于移除开头或结尾处的特定字符。

>>> print (np.char.strip('ashok arunooba','a'))
shok arunoob
>>> print (np.char.strip(['arunooba','admin','java'],'a'))
['runoob' 'dmin' 'jav']

numpy.char.join() 函数通过指定分隔符来连接数组中的元素或字符串

>>> print (np.char.join(':','runoob'))
r:u:n:o:o:b
>>> print (np.char.join([':','-'],['runoob','google']))
['r:u:n:o:o:b' 'g-o-o-g-l-e']

numpy.char.replace() 函数使用新字符串替换字符串中的所有子字符串。

>>> print (np.char.replace ('i like xiaozemaliya', 'xiaoze', 'zuozuo'))
i like zuozuomaliya

numpy.char.encode() 函数对数组中的每个元素调用 str.encode 函数。 默认编码是 utf-8,可以使用标准 Python 库中的编解码器。

>>> a = np.char.encode('runoob', 'cp500') 
>>> print (a)
b'\x99\xa4\x95\x96\x96\x82'
>>> 

numpy.char.decode() 函数对编码的元素进行 str.decode() 解码。

>>> a = np.char.encode('runoob', 'cp500') 
>>> print (a)
b'\x99\xa4\x95\x96\x96\x82'
>>> a = np.char.encode('runoob', 'cp500') 
>>> print (a)
b'\x99\xa4\x95\x96\x96\x82'
>>> print (np.char.decode(a,'cp500'))
runoob

猜你喜欢

转载自blog.csdn.net/zcb_data/article/details/110098062