PHP Conference Japan 2024

pathinfo

(PHP 4 >= 4.0.3, PHP 5, PHP 7, PHP 8)

pathinfo返回有关文件路径的信息

描述

pathinfo(字符串 $path, 整数 $flags = PATHINFO_ALL): 数组|字符串

pathinfo() 返回有关 path 的信息:根据 flags,可以是关联数组或字符串。

注意:

有关检索当前路径信息的信息,请阅读有关 预定义保留变量 的部分。

注意:

pathinfo() 对输入字符串进行简单操作,并且不知道实际的文件系统或路径组件,例如 ".."。

注意:

仅在 Windows 系统上,\ 字符将被解释为目录分隔符。在其他系统上,它将像任何其他字符一样对待。

警告

pathinfo() 是区域设置感知的,因此要使其正确解析包含多字节字符的路径,必须使用 setlocale() 函数设置匹配的区域设置。

参数

path

要解析的路径。

flags

如果存在,则指定要返回的特定元素;PATHINFO_DIRNAMEPATHINFO_BASENAMEPATHINFO_EXTENSIONPATHINFO_FILENAME 之一。

如果未指定 flags,则返回所有可用元素。

返回值

如果未传递 flags 参数,则返回一个关联 数组,其中包含以下元素:dirnamebasenameextension(如果有)和 filename

注意:

如果 path 有多个扩展名,PATHINFO_EXTENSION 仅返回最后一个扩展名,而 PATHINFO_FILENAME 仅去除最后一个扩展名。(请参阅下面的第一个示例)。

注意:

如果 path 没有扩展名,则不会返回 extension 元素(请参阅下面的第二个示例)。

注意:

如果 pathbasename 以点开头,则后续字符将被解释为 extension,并且 filename 为空(请参阅下面的第三个示例)。

如果存在 flags,则返回一个包含请求元素的 字符串

示例

示例 #1 pathinfo() 示例

<?php
$path_parts
= pathinfo('/www/htdocs/inc/lib.inc.php');

echo
$path_parts['dirname'], "\n";
echo
$path_parts['basename'], "\n";
echo
$path_parts['extension'], "\n";
echo
$path_parts['filename'], "\n";
?>

以上示例将输出

/www/htdocs/inc
lib.inc.php
php
lib.inc

示例 #2 pathinfo() 示例,显示空值和无扩展名之间的区别

<?php
$path_parts
= pathinfo('/path/emptyextension.');
var_dump($path_parts['extension']);

$path_parts = pathinfo('/path/noextension');
var_dump($path_parts['extension']);
?>

以上示例将输出类似于以下内容

string(0) ""

Notice: Undefined index: extension in test.php on line 6
NULL

示例 #3 pathinfo() 点文件的示例

<?php
print_r
(pathinfo('/some/path/.test'));
?>

以上示例将输出类似于以下内容

Array
(
    [dirname] => /some/path
    [basename] => .test
    [extension] => test
    [filename] =>
)

示例 #4 pathinfo() 使用数组解构的示例

flags 参数不是位掩码。只能提供单个值。要仅选择一组有限的解析值,请使用如下所示的数组解构

<?php
['basename' => $basename, 'dirname' => $dirname] = pathinfo('/www/htdocs/inc/lib.inc.php');

var_dump($basename, $dirname);
?>

以上示例将输出类似于以下内容

string(11) "lib.inc.php"
string(15) "/www/htdocs/inc"

参见

添加注释

用户贡献的注释 3 条注释

Pietro Baricco
12 年前
使用此函数代替 pathinfo,使其也能与 UTF-8 编码的文件名一起使用



<?php
function mb_pathinfo($filepath) {
preg_match('%^(.*?)[\\\\/]*(([^/\\\\]*?)(\.([^\.\\\\/]+?)|))[\\\\/\.]*$%im',$filepath,$m);
if(
$m[1]) $ret['dirname']=$m[1];
if(
$m[2]) $ret['basename']=$m[2];
if(
$m[5]) $ret['extension']=$m[5];
if(
$m[3]) $ret['filename']=$m[3];
return
$ret;
}
?>
urvi
2 年前
关于路径,有一点需要注意
在 Windows 中,斜杠 (/) 和反斜杠 (\) 都用作目录分隔符。在其他环境中,它是正斜杠 (/)。(此解释来自 basename() 函数部分 https://php.net/manual/en/function.basename.php
示例
<?php
$path
= "https://urvidutta.com /a\b\c\filename.pdf";

echo
pathinfo($pdfUrl, PATHINFO_BASENAME); // 获取基本名称
// 输出
// 在 Windows 上:结果为 filename.pdf
// 在 Linux 上:结果为 a\b\c\filename.pdf(这可能不是您期望的)

// 因此,为了在不同的系统中获得相同的结果,我将首先执行以下操作。
$path = str_replace($path, '\\', '/'); // 将 '\' 转换为 '/'
?>
n0dalus
19 年前
如果文件有多个“文件扩展名”(用句点分隔),则将返回最后一个扩展名。
例如
<?php
$pathinfo
= pathinfo('/dir/test.tar.gz');
echo
'Extension: '.$pathinfo['extension'];
?>
将产生
Extension: gz

而不是 tar.gz
To Top