为什么非贪婪模式导致字符串匹配只提取图片名?

2026-03-31 22:371阅读0评论SEO资源
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计349个文字,预计阅读时间需要2分钟。

为什么非贪婪模式导致字符串匹配只提取图片名?

将给定的代码简化,并确保不超过100个字:

pythons=http://example.com/image.jpgprint(s.split('/')[-1])

local s = "example.com/image.jpg" print(string.match(s, "/(.-)%.jpg"))

这给了我

--> /example.com/image

但是我想得到

--> image 由于正则表达式引擎从左到右处理一个字符串,你的模式找到第一个/,然后.-匹配任何字符(.)尽可能少(.)直到第一个字面. (与%匹配)后跟jpg子串.

你需要使用一个否定的字符类[^ /](匹配任何char但/)而不是.匹配任何字符:

local s = "example.com/image.jpg" print(string.match(s, "/([^/]+)%.jpg")) -- => image

见online Lua demo

为什么非贪婪模式导致字符串匹配只提取图片名?

[^ /]匹配任何字符但/,因此,最后/将匹配模式“/([^ /])%.jpg”中的第一个/.它会匹配为

从模式中删除第一个/不是一个好主意,因为它会使引擎在尝试查找匹配时使用更多冗余步骤,/将“锚定”/符号处的量化子模式.引擎更容易找到/而不是寻找0(从头开始未定义)除了/之外的字符数.

如果您确定此字符串出现在字符串的末尾,请在模式的末尾添加$(如果您需要,则实际上并不清楚,但在一般情况下可能最好).

本文共计349个文字,预计阅读时间需要2分钟。

为什么非贪婪模式导致字符串匹配只提取图片名?

将给定的代码简化,并确保不超过100个字:

pythons=http://example.com/image.jpgprint(s.split('/')[-1])

local s = "example.com/image.jpg" print(string.match(s, "/(.-)%.jpg"))

这给了我

--> /example.com/image

但是我想得到

--> image 由于正则表达式引擎从左到右处理一个字符串,你的模式找到第一个/,然后.-匹配任何字符(.)尽可能少(.)直到第一个字面. (与%匹配)后跟jpg子串.

你需要使用一个否定的字符类[^ /](匹配任何char但/)而不是.匹配任何字符:

local s = "example.com/image.jpg" print(string.match(s, "/([^/]+)%.jpg")) -- => image

见online Lua demo

为什么非贪婪模式导致字符串匹配只提取图片名?

[^ /]匹配任何字符但/,因此,最后/将匹配模式“/([^ /])%.jpg”中的第一个/.它会匹配为

从模式中删除第一个/不是一个好主意,因为它会使引擎在尝试查找匹配时使用更多冗余步骤,/将“锚定”/符号处的量化子模式.引擎更容易找到/而不是寻找0(从头开始未定义)除了/之外的字符数.

如果您确定此字符串出现在字符串的末尾,请在模式的末尾添加$(如果您需要,则实际上并不清楚,但在一般情况下可能最好).