在一天的大部分时间里,我一直在尝试构建这个递归函数,但我似乎无法让它以我想要的方式工作。
首先,我有一个属性,其中包含函数必须访问的一些数据:
$this->data
然后我有这个字符串,它的目的是变成一个相对路径:
$path = 'path.to.%id%-%folder%.containing.%info%';
像这样的字符串部分: %value% 将加载在$this->data property
(像这样:$this->data['id'];
或$this->data['folder'];
为了让事情变得真正有趣,该属性可以像这样再次引用自己:$this->data['folder'] = 'foldername.%subfolder%';
并且还有两个 %values% 由 a 分隔 - 必须单独放置。
所以对于这个问题,我一直在尝试创建一个递归函数,该函数将从数据属性中加载动态值,然后如果新值包含另一个 %value% 等等,直到不再有 %value%加载。
到目前为止,这是我能够想出的:
public function recursiveFolder( $folder, $pathArr = null )
{
$newPathArr = explode( '.', $folder );
if ( count ( $newPathArr ) !== 1 )
{
foreach( $newPathArr as $id => $folder )
{
$value = $this->recursiveFolder( $folder, $newPathArr );
$resultArr = explode( '.', $value );
if ( count ( $resultArr ) !== 1 )
{
foreach ( $resultArr as $nid => $result )
{
$nvalue = $this->recursiveFolder( $result, $newPathArr );
$resultArr[$nid] = $nvalue;
}
}
$resultArr = implode( '.',$resultArr );
$newPathArr[$id] = $resultArr;
}
}
else
{
$pattern = '/%(.*?)%/si';
preg_match_all( $pattern, $folder, $matches );
if ( empty( $matches[0] ) )
{
return $folder;
}
foreach ( $matches[1] as $mid => $match )
{
if ( isset( $this->data[$match] ) && $this->data[$match] != '' )
{
$folder = str_replace( $matches[0][$mid], $this->data[$match], $folder );
return $folder;
}
}
}
return $newPathArr;
}
不幸的是,它根本不是一个递归函数,因为当它具有多个 %values% 层时它会停止运行,但是几乎可以使用两层。(我只是对其进行了编码,以便它可以在这一点上以极简主义的水平工作)。
这是它应该如何工作的:
它应该变成:
'files.%folder%.blog-%type%.and.%time%'
进入:
'files.foldername.blog-post.and.2013.feb-12th.09'
基于此:
$data['folder'] = 'foldername';
$data['type'] = 'post';
$data['time'] = '%year%.%month%-%day%';
$data['year'] = 2013;
$data['month'] = 'feb';
$data['day'] = '12th.%hour%';
$data['hour'] = '09';
希望你能帮忙!周杰伦