excel单元格提取汉字,怎么用一个函数做到,一下,谢谢

周三疯- 2024-06-16 03:46:19
最佳回答
如果汉字位于字符串的开头或结尾,用left或right函数即可提取,例如上图中a2:a4区域中的字符串。在b2中输入下面的公式: =left(a2,lenb(a2)-len(a2)) 就会返回字符串中开头的几个汉字。 说明:lenb函数和len函数都可用返回文本字符串中的字符数,不同的是,lenb函数会将每个汉字(双字节字符)的字符数按2计数,len函数则对所有的字符,无论是单字节还是双字节都按1计数,因而公式中的“lenb(a2)-len(a2)”返回文本字符串中的汉字个数。 同样对于a6:a8区域中的字符串,在b6中用right函数即可: =right(a6,lenb(a6)-len(a6)) 如果汉字位于字符串的中间,可使用下面的数组公式。 =mid(a10,match(2,lenb(mid(a10,row(indirect("1:"&len(a10))),1)),),lenb(a10)-len(a10)) 公式输入完毕,按ctrl+shift+enter结束。 说明:公式先用mid函数将字符串中的每个字符分解到到一个字符数组中,然后用lenb函数返回各字符的的字符数,对于汉字会返回“2”。用match函数取得第一个“2”的位置,即第一个汉字的位置,最后再用mid函数提取汉字。 使用上述公式时要求字符串中的汉字是连续的,中间没有其它字符分隔。如果字符串中的汉字之间有其它字符分隔,例如上图中的a14单元格,要提取其中的所有汉字,可用下面的自定义函数。方法是: 1. 按alt+f11,打开vba编辑器,单击菜单“插入→模块”,在代码窗口中输入粘贴下面的代码:function 提取汉字(sstring as string) as stringdim regex as objectset regex = createobject("vbscript.regexp")with regex '搜索整个字符串 .global = true '匹配非汉字 .pattern = "[^\u4e00-\u9fa5]" '将字符串中的非汉字替换为空 提取汉字 = .replace(sstring, "")end withset regex = nothingend function 20210311
汇率兑换计算器

类似问答
汇率兑换计算器

热门推荐
热门问答
最新问答
推荐问答
新手帮助
常见问题
房贷计算器-九子财经 | 备案号: 桂ICP备19010581号-1 商务联系 企鹅:2790-680461

特别声明:本网为公益网站,人人都可发布,所有内容为会员自行上传发布",本站不承担任何法律责任,如内容有该作者著作权或违规内容,请联系我们清空删除。