gpt4 book ai didi

c# - 用于将 CSS 边框属性拆分为多个部分的正则表达式

转载 作者:技术小花猫 更新时间:2023-10-29 11:24:23 25 4
gpt4 key购买 nike

我想将 CSS 中的边框属性拆分为其组成部分,即:

.someClass{
border: 1px solid black;
}

进入

border-width: 1px
border-style: solid;
border-color: black;

我已经把 border: 和分号分开了,所以我只需要解析属性的值部分

现在在 CSS 中,您可以任意组合上述 3 个属性,所以

border: 1px solid;
border: solid Gold;
border: 1em;
border: 1mm #000000;
border: 1px inset rgb(12, 44, 199);

所有这些都是合法的,所以我需要对此负责。

我目前的情况是

([0-9]+[a-zA-Z|%]+)* *([a-zA-Z]*) *( .*)

这在正常情况下工作正常,但在“1px Solid”情况下失败,因为 Solid 被放入第 3 个捕获组,而不是第 2 个。我不是正则表达式专家,所以我可能会犯非常基本的错误,但我们将不胜感激任何帮助。我正在使用 C#(但主要是在 http://gskinner.com/RegExr/ 中进行测试,所以任何差异都可能是问题所在)

最佳答案

简单地在表达式的开头包含 border: 似乎是一个主要帮助,因为它不会意外匹配第二组或第三组。同样,在表达式末尾添加 ; 可防止过早捕获第二组或第三组。除此之外,将第二组从 * 更改为 + 也有帮助,因为这允许它按预期匹配第二组而不是第三组。总之,试试这个:

border: ([0-9]+[a-zA-Z|%]+)* *([a-zA-Z]+)* *( .*)*;

我怀疑这是否完美,如果您需要 100% 的结果,您可能不应该使用单个正则表达式,而是标记化和解析字符串(我非常怀疑 CSS 规则是否完全使用正则表达式解析),但是如果这适用于您需要的有限规则,非常棒。

关于c# - 用于将 CSS 边框属性拆分为多个部分的正则表达式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14718745/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com