我一直在尝试在一天中的大部分时间内构建这个递归函数,但我似乎无法按照我想要的方式工作。
首先,我有一个属性,其中包含函数必须访问的一些数据:
$this->data
然后我有了这个字符串,其目的是变成一个相对路径:
$path = 'path.to.%id%-%folder%.containing.%info%';
字符串中的部分如下所示:%value%将加载$this->data property
中找到的一些动态值(如:$this->data['id'];
或$this->data['folder'];
为了让事情变得非常有趣,该属性可以像这样再次引用自己:$this->data['folder'] = 'foldername.%subfolder%';
并且还有两个由%分隔的%值 - 必须保持不变。
所以对于这个问题,我一直在尝试创建一个递归函数,它将从data属性加载动态值,然后再次如果新值包含另一个%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;
}
不幸的是,它根本不是一个递归函数,因为当它有多个%值%的%时,它会停止运行,但是可以使用两个层 - 几乎 - 。 (我只是对它进行编码,以便在这一点上以极简的水平工作)。
以下是它应该如何运作:
应该转:
'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';
希望你能帮忙! 杰
答案 0 :(得分:1)
我认为不需要递归地解决这个问题:
<?php
function putData($str, $data)
{
// Repeat the replacing process until no more matches are found:
while (preg_match("/%(.*?)%/si", $str, $matches))
{
// Use $matches to make your replaces
}
return $str;
}
?>