首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >雨量计皮肤问题中的RegExp

雨量计皮肤问题中的RegExp
EN

Stack Overflow用户
提问于 2014-06-18 03:32:22
回答 1查看 1.4K关注 0票数 0

我正在创建一个雨量计皮肤,我需要读取一个本地文件的内容,然后拆分它的内容。

我的本地文件的内容类似于:

代码语言:javascript
复制
sentence 1
sentence 2
sentence 3
sentence 4

我的Rainmeter webparser度量如下所示:

代码语言:javascript
复制
[MeasureParser]
Measure=Plugin
Plugin=WebParser.dll
Url=File://#SKINSPATH#\Notes\Files\notes.txt
RegExp="((.*)((?>\r\n|\n|\r)?))+" 

然后,我的单个字符串索引器将如下所示

代码语言:javascript
复制
[MeasureParserChild1]
Measure=Plugin
Plugin=WebParser.dll
Url=[MeasureParser]
StringIndex=1

我想要它做的是用换行符(?>\r\n|\n|\r)拆分文件内容,但显然它对我不起作用。我读取正则表达式的方式类似于有多个字符(.*),后面可能有一个可选的换行符(?>\r\n|\n|\r)? (如果我的文件中只有一行。然后所有的(.*)((?>\r\n|\n|\r)?)都可以出现几次(1次或更多次)。

无论如何,它不能工作,所以我的思考中有一个缺陷,我希望有人能帮我找到它。

非常感谢您的任何可能的帮助。:)

EN

回答 1

Stack Overflow用户

发布于 2015-01-27 07:26:00

首先,你不能简单地量化你的整个模式,并希望用索引引用每个匹配,正则表达式不是这样工作的,它会吞噬所有可能的匹配,并返回最后一个匹配。

其次,由于您已将行内容设置为零或更多,并将换行符部分设置为可选,因此最后一个匹配项可能始终为空字符串。

您真正需要的是创建一个变量来保存匹配单行的模式,例如^(.+)$就足够了,因为它将使用锚点^$来匹配字符串的开头和结尾。然后,您将想要多次使用该变量,只要您想要返回行。

如果你想从你的文件中读取5行代码,你可以执行类似RegExp=(?m)#SingleLine##SingleLine##SingleLine##SingleLine##SingleLine#的操作。修饰符(?m)用于确保^$匹配一行的开头和结尾,而不是试图匹配整个文件的开头和结尾。然后,可以引用索引为1到5的行。

如果你想要一些更动态的东西,你不需要重复这个模式,并且让它根据你的文件大小自动缩放,你可能不得不求助于一些Lua脚本。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24271906

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档