业界最为标准的中英文排版格式,中文和英文之间加空格,中文和数字之间加空格。现在微信(安卓 6.6.2 测试版)已经支持。
 
原理其实这个很简单,就是匹配相连接的中文和英文(包括数字),然后在中间加一个空格即可。接下来用 JS 和 Golang 实现。需要注意的是已经符合排版的就不需要加空格了。
匹配中文是用的 [\u4e00-\u9fa5],一般而言的中文就都涵盖。
Go 实现
| 1 | package main | 
JS 实现
| 1 | var s = "我是渣渣辉,我是zhangjiahui,zhangjiahui 是我"; | 
这里需要注意的是大部分常用的中文都可以匹配到,因为超出了 \uffff 所以部分生僻的中文还匹配不到,可以按照需要进行扩增。JS 因为使用 UTF-16 编码,再使用的时候需要再加上 u 修饰符,例如如 /\u{20BB7}/u.test('𠮷')。
原文首发在我的 GitHub 博客
更新
看到一篇文章,JavaScript 正则表达式匹配汉字,这里需要修改一下正则,最近有一个新的 ES 提案中包含了一个 unicode 转义,语法为 \p{…}。Chrome 64 已经支持,兼容处理可以使用@babel/plugin-proposal-unicode-property-regex 和 regexpu-core 。
所以正则可以修改为 /(\p{Unified_Ideograph})(\w)/gu。
以前没接触过这个正则语法,Go 是已经支持了这种语法,所以 Go 的正则也需要改成这个。
不过我尝试了 Unified_Ideograph 这个就报错了,需要修改为 Han 就可以了。
| 1 | g1 := regexp.MustCompile("(\\p{Han})(\\w)") | 
更新二
上述有个问题,\w 匹配任意的字母、数字和下划线,相当于[A-Za-z0-9_]。
| 1 | const g = /(\p{Unified_Ideograph})([A-Za-z0-9])|([A-Za-z0-9])(\p{Unified_Ideograph})/gu | 
这里也改进了正则只需要使用一个,需要注意的是,那么使用替换原则的话,后面的组匹配是在第一二个匹配之后,所以要使用 $3, $4。