[英]How to extract a filename using regex from an absolute path
我正在尝试从以下行中提取文件名:
"GET /mapitzend/public/components/font-awesome/css/font-awesome.css HTTP/1.1" 200 26651
在这种情况下,预期的结果应该是“ font-awesome.css”。
\"(.[^\"]+)\s+HTTP
上面的正则表达式将返回:“ GET /mapitzend/public/components/font-awesome/css/font-awesome.css HTTP
我在这里想念什么..
试试这个正则表达式:
(?<=\\/)[^\\s\\/]*(?=\\s*HTTP)
说明:
(?<=\\/)
-向后寻找正号,以找到紧跟/
的位置 [^\\s\\/]*
-匹配0+次出现的既不是空格字符也不是/
的任何字符 (?=\\s*HTTP)
-要匹配的正向超前,直到位置紧跟着0+空格和HTTP
。 虽然可以使用regex
提取文件名,但是开始使用regex
提取路径然后使用basename()
或pathinfo()
获取文件名更容易:
$line = '"GET /mapitzend/public/components/font-awesome/css/font-awesome.css HTTP/1.1" 200 26651';
$m = array();
if (preg_match('/GET (.*) HTTP/', $line, $m)) {
$filename = basename($m[1]);
}
仅使用regex
:
if (preg_match('#GET /(.*/)*(.*) HTTP#', $line, $m)) {
$filename = $m[2];
}
使用扩展名为.css
, .html
的文件名的属性,可以使用以下正则表达式。
正则表达式: [^\\/]+?\\.[az]+
说明:
[^\\/]+?
匹配前一个字符为/
的字符串。
\\.[az]+
与扩展名匹配,以确保它是文件。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.