本文主要介绍笔者在做开源鸿蒙应用开发时,ArkTs 中使用正则表达式处理像 string 等字符串对象。
一些 ArkTs 使用正则表达式示例,以及一些可能比较常用的小技巧。
正则表达式的一些应用技巧,涉及到匹配模式。
正则表达式在开源鸿蒙应用开发中,可以起到怎样的一个应用。
传统的解决方式:相信我的读者可能都有一些 DS 的基础,知道这种其实就是字符串匹配问题,针对这种问题,常见的解法是使用:暴力匹配、KMP、AC 自动机等方式,但是在实际应用当中如果这样做,可能比较蠢。
我此前有过在 Python 中使用过具有正则表达(式)匹配功能的 re 模块的经历。但是 ArkTs 并没有类似的集成 API。
但是在 ArkTs 的相关文档以及文章中,对这一块的描述都比较少。从官方的描述来看,我们可以知道 ArkTs 是 TypeScript 和 JavaScript 的超集,兼容了JS/TS的语言生态。
所以我在写这篇文章的时候,看了不少 JS 和 TS 关于正则表达式的使用的文档。
<img src=“https://img-blog.csdnimg.cn/c2a4bff044674a92926d9bade2262094.png” alt=“在这里插入图片描述” style=“zoom:100%;” />
正则表达式在ArkTs的使用
①变量 RegExp
在 ArkTs 中,正则表达式的变量类型是 RegExp,这一点基本上兼容了 JS。有两种表达方式。
let rep: RegExp = /a\S+b/;
let rep = new RegExp("a\S+b");
正则表达式的变量使用较多,主要有:
let rep: RegExp = /acfun1+/;
let s: string = "bkacfun1112";
console.log(s.match(rep)[0]); // acfun111
let rep: RegExp = /acfun1+/;
let s: string = "bkacfun1112";
console.log('' + rep.test(string) ? 'yes' : 'no'); // yes
match 查到的是一个第一个,但如果想匹配所有符合正则表达式的,可以使用 matchAll,这个返回的是一个迭代器,这个就不给出用例了,感兴趣的朋友可以自行去 js 的相关文档。
search,在字符串中查找匹配的位置(第一个),成功时返回匹配的位置,失败返回 -1。
replace,即用字符串替换匹配到的字符子串。
上面的文字描述可能会比较抽象,下面用示例来表示:注释中即为输出内容
import re
s = 'sttstts'
pat = re.compile(r's.*s')
print(pat.match(pat).group(0)) # stts
let rep: RegExp = /s.*s/
let s: string = 'sttstts'
console.log(s.match(rep)[0]) // sttstts
以上这两种情况其实就是,在正则表达式的相关概念中,其实就是关于匹配模式中的贪婪模式与懒惰模式。
关于这两种的详细概念,如果朋友们想要了解,不妨去看看正则表达式的文档。
我在这里将用比较简单、浅显的文字表述来解释这两种模式:这两种模式,具体的运作其实就和名字一样。
贪婪模式其实就是尽可能匹配比较长的字符串,如上面的例子 2 中的输出,匹配过程很贪婪,和贪心算法思想类似,尽可能使匹配的结果长;而懒惰模式类似,就是匹配尽可能少的字符串,匹配到满足的即可。
这两种模式,其实就是为了让开发者能更加灵活的使用正则表达式。这种两种模式的区别主要体现在匹配多个字符的特殊正则表达式字符,比如正则表达式中 +, * 等。
那么,如果你是 ArkTs 开发者,你要用懒惰模式,但是在 ArkTs 中,正则表达式默认是贪婪的。如何切换到懒惰模式呢?
let rep: RegExp = /s.*?s/
let s: string = 'sttstts'
console.log(s.match(rep)[0]) // stts
上述的用 ? 后,就匹配最少的字符。
正则表达式应用
相信通过上文的了解,我们已经可以对正则表达式的已经有了简单的认知,尤其是通过这些使用的示例,很容易知道,从直接角度,正则表达式的应用是对字符串这种类型的数据处理。这种处理是查询匹配,替换。
通过上述的直接角度,我们可以对字符串数据,即文本数据,可以用于做字符串过滤,在很多有查找,替换功能的应用(比如大家常用的编辑器 vscode,记事本),这些功能其实就有正则表达式影子。
这个是我在编写 OpenHarmony 应用时,遇到的一个场景:使用 @ohos.net.http 库中相关 api 向服务器发送 http 请求,会收到 http 报文。
这种报文并不只是数据,还会有其他的部分。而我需要提取数据部分,且要分别提取出数据部分的某些字段。
Code(ArKTs)<img src=“https://img-blog.csdnimg.cn/3697ae7b9181471ba24cab23c53d0dc4.png” alt=“在这里插入图片描述” style=“zoom:150%;” />
求分享
求点赞
求在看
文章引用微信公众号"OST开源开发者",如有侵权,请联系管理员删除!