在对字符串进行操作时,常常需要获取字符串长度、截取字符串、替换字符串等等,以下介绍几种常用的字符串处理函数:
1. 获取字符串长度编辑
使用 len() 函数来获取字符串的长度,并且会把空字符串也计算在内。
在单元格中输入:=len("Hello FineReport!"),返回 Hello FineReport! 的长度即返回值为 17。
2. 截取字符串编辑
截取字符串可以使用 mid(),left(),right () 这三个函数实现截取字符串。
2.1 从指定位置开始截取
mid(text,start_num,num_chars),就是返回字符串指定位置开始的一定长度的字符串。
在单元格中输入:=mid("Hello FineReport!",7,11),从第 7 位截取长度为 11 的字符串即返回值为"FineReport!"。
注:mid 函数的 start_num 值不能小于 1,num_chars 不能为负数,否则将返回错误信息*VALUE!。
2.2 从左边字符串开始截取
left(text,num_chars),就是从左边字符串开始返回一定长度的字符串。
在单元格中输入:=left("Hello FineReport!",5),从左边开始截取长度为 5 的字符串即返回值为:"Hello"。
在单元格中输入:=left("Hello FineReport!"),如 num_chars 没有填写默认的为截取 1 个字符串即返回值为:"H"。
2.3 从右边字符串开始截取
right(text,num_chars),就是从右边字符串开始返回一定长度的字符串。
在单元格中输入:=right("Hello FineReport!",5),从右边开始截取长度为 5 的字符串即返回值为:"port!"。
在单元格中输入:=right("Hello FineReport!"),num_chars 没有填写默认的为截取 1 个字符串即返回值为:"!"。
3. 替换字符串编辑
替换字符串可以使用 replace 函数,其参数形式有两种,下面我们来看下。
3.1 替换指定字符串中的内容
REPLACE(text, texttoreplace, replacetext),将指定的字符串转换成其它字符串。
如数据列的所有数据都包含“¥”,若要将“¥”转换为元,则在对应单元格的高级>自定义显示中填写:=replace($$$,"¥","元"),则在预览时,对应的"¥"就变成元了。
3.2 替换指定字符串长度中的内容
REPLACE(old_text,start_num,num_chars,new_text),将制定字符串的长度进行替换。
如在单元格中填写:=replace("0123456789",2,5,"1"),即从第二字符开始一共五个字符替换成"1",也就是将"12345"转换成"1",因此结果是:"016789"
4. 获取特定字符串所在位置编辑
FIND(find_text,within_text,start_num):从指定的索引(start_num)处开始,返回第一次出现的指定子字符串(find_text)在此字符串(within_text)中的索引。
Find_text:需要查找的文本或包含文本的单元格引用。
Within_text:包含需要查找文本的文本或单元格引用。
Start_num:指定进行查找字符的索引位置。within_text 里的索引从 1 开始。如果省略 start_num,则假设值为 1。
备注:
如果 find_text 不在 within_text 中,FIND 函数返回值为 0。
如果 start_num 不大于 0,FIND 函数返回错误信息*VALUE!。
如果 start_num 大于 within_text 的长度,FIND 函数返回值为 0。
如果 find_text 是空白文本,FIND 函数将在搜索串中匹配第一个字符(即编号为 start_num 或 1的字符)。
示例:
FIND("I","Information")等于 1。
FIND("i","Information")等于 9。
FIND("o","Information",2)等于 4。
FIND("o","Information",12)等于 0。
FIND("o","Information",-1)等于 *VALUE!。