3 回答
TA贡献1810条经验 获得超5个赞
你可以试试
#(?:[0-9A-Fa-f]{6}|[0-9A-Fa-f]{3})(?=;|[^(]*\))
所以这里的想法是6
如果没有找到匹配字符匹配,则以更高的优先级匹配字符长度3
,以确保它不匹配#BED
或者我们需要匹配十六进制颜色代码的终止,所以我们使用带有交替的前瞻
TA贡献1860条经验 获得超8个赞
您可以使用
r = re.compile(r'#[0-9A-Fa-f]{3}(?:[0-9A-Fa-f]{3})?(?!$)', re.M)
见证明
示例 Python 代码:
import re
regex = r"#[0-9A-Fa-f]{3}(?:[0-9A-Fa-f]{3})?(?!$)"
test_str = ("#BED\n"
"{\n"
" color: #FfFdF8; background-color:#aef;\n"
" font-size: 123px;\n"
" background: -webkit-linear-gradient(top, #f9f9f9, #fff);\n"
"}\n"
"#Cab\n"
"{\n"
" background-color: #ABC;\n"
" border: 2px dashed #fff;\n"
"}")
matches = re.findall(regex, test_str, re.MULTILINE)
print(matches)
TA贡献1900条经验 获得超5个赞
一方面,您可以先匹配 6 位代码,否则匹配 3 位代码将首先匹配其中一半(因此不匹配完整的 6 位代码)。但是,由于您还只想匹配 CSS 属性规则,而不是选择器,请提前查找;
、,
或)
:
(?i)#(?:[0-9a-f]{6}|[0-9a-f]{3})(?=[;,)])
https://regex101.com/r/BtZaoV/2
如果您还需要能够排除组合选择器,例如#BED, foo {
,您可以先查看非{
s 后跟}
:
(?i)#(?:[0-9a-f]{6}|[0-9a-f]{3})(?=[^{]*})
https://regex101.com/r/BtZaoV/3
使用不区分大小写的标志来保持 DRY。(您也可以{3}){1,2}
用来避免重复字符集,但这会使模式更难阅读 IMO)
添加回答
举报