私は配列を持っています:
_$a = array('foo' => 'fooMe');
_
そして私は:
_print_r($a);
_
印刷するもの:
_Array ( [foo] => printme )
_
関数があるので、そうするとき:
_needed_function(' Array ( [foo] => printme )');
_
配列array('foo' => 'fooMe');
を取得しますか?
実際に、「文字列配列」を実際の配列に解析する関数を作成しました。明らかに、それはややハック的でありませんが、私のテストケースでは動作します。 http://codepad.org/idlXdij で機能するプロトタイプへのリンクを次に示します。
リンクをクリックする気にならない人のために、コードもインラインで投稿します。
<?php
/**
* @author ninetwozero
*/
?>
<?php
//The array we begin with
$start_array = array('foo' => 'bar', 'bar' => 'foo', 'foobar' => 'barfoo');
//Convert the array to a string
$array_string = print_r($start_array, true);
//Get the new array
$end_array = text_to_array($array_string);
//Output the array!
print_r($end_array);
function text_to_array($str) {
//Initialize arrays
$keys = array();
$values = array();
$output = array();
//Is it an array?
if( substr($str, 0, 5) == 'Array' ) {
//Let's parse it (hopefully it won't clash)
$array_contents = substr($str, 7, -2);
$array_contents = str_replace(array('[', ']', '=>'), array('#!#', '#?#', ''), $array_contents);
$array_fields = explode("#!#", $array_contents);
//For each array-field, we need to explode on the delimiters I've set and make it look funny.
for($i = 0; $i < count($array_fields); $i++ ) {
//First run is glitched, so let's pass on that one.
if( $i != 0 ) {
$bits = explode('#?#', $array_fields[$i]);
if( $bits[0] != '' ) $output[$bits[0]] = $bits[1];
}
}
//Return the output.
return $output;
} else {
//Duh, not an array.
echo 'The given parameter is not an array.';
return null;
}
}
?>
配列を文字列として保存する場合は、 serialize
を使用します[ドキュメント] および unserialize
[ドキュメント] .
あなたの質問に答えるために:いいえ、print_r
の出力を再び配列に解析する組み込み関数はありません。
サブ配列を使用した配列出力の場合、 ninetwozero で提供されるソリューションは機能しません。複雑な配列で機能するこの関数を試すことができます。
<?php
$array_string = "
Array
(
[0] => Array
(
[0] => STATIONONE
[1] => 02/22/15 04:00:00 PM
[2] => SW
[3] => Array
(
[0] => 4.51
)
[4] => MPH
[5] => Array
(
[0] => 16.1
)
[6] => MPH
)
[1] => Array
(
[0] => STATIONONE
[1] => 02/22/15 05:00:00 PM
[2] => S
[3] => Array
(
[0] => 2.7
)
[4] => MPH
[5] => Array
(
[0] => 9.61
)
[6] => MPH
)
)
";
print_r(print_r_reverse(trim($array_string)));
function print_r_reverse(&$output)
{
$expecting = 0; // 0=nothing in particular, 1=array open paren '(', 2=array element or close paren ')'
$lines = explode("\n", $output);
$result = null;
$topArray = null;
$arrayStack = array();
$matches = null;
while (!empty($lines) && $result === null)
{
$line = array_shift($lines);
$trim = trim($line);
if ($trim == 'Array')
{
if ($expecting == 0)
{
$topArray = array();
$expecting = 1;
}
else
{
trigger_error("Unknown array.");
}
}
else if ($expecting == 1 && $trim == '(')
{
$expecting = 2;
}
else if ($expecting == 2 && preg_match('/^\[(.+?)\] \=\> (.+)$/', $trim, $matches)) // array element
{
list ($fullMatch, $key, $element) = $matches;
if (trim($element) == 'Array')
{
$topArray[$key] = array();
$newTopArray =& $topArray[$key];
$arrayStack[] =& $topArray;
$topArray =& $newTopArray;
$expecting = 1;
}
else
{
$topArray[$key] = $element;
}
}
else if ($expecting == 2 && $trim == ')') // end current array
{
if (empty($arrayStack))
{
$result = $topArray;
}
else // pop into parent array
{
// safe array pop
$keys = array_keys($arrayStack);
$lastKey = array_pop($keys);
$temp =& $arrayStack[$lastKey];
unset($arrayStack[$lastKey]);
$topArray =& $temp;
}
}
// Added this to allow for multi line strings.
else if (!empty($trim) && $expecting == 2)
{
// Expecting close parent or element, but got just a string
$topArray[$key] .= "\n".$line;
}
else if (!empty($trim))
{
$result = $line;
}
}
$output = implode("\n", $lines);
return $result;
}
/**
* @param string $output : The output of a multiple print_r calls, separated by newlines
* @return mixed[] : parseable elements of $output
*/
function print_r_reverse_multiple($output)
{
$result = array();
while (($reverse = print_r_reverse($output)) !== NULL)
{
$result[] = $reverse;
}
return $result;
}
?>
1つの小さなバグがあります。空の値(空の文字列)がある場合、以前の値に埋め込まれます。
いいえ。ただし、serialize
関数とjson_*
関数の両方を使用できます。
$a = array('foo' => 'fooMe');
echo serialize($a);
$a = unserialize($input);
または:
echo json_encode($a);
$a = json_decode($input, true);
print_r
でこれを行うことはできません。var_export
は似たようなものを許可する必要がありますが、正確にはあなたが要求したものではありません
http://php.net/manual/en/function.var-export.php
$val = var_export($a, true);
print_r($val);
eval('$func_val='.$val.';');
その名前が何であるかを正確に行う素敵なオンラインツールがあります:
JSONオブジェクトから json_decode 関数を使用して配列を作成することはそれほど遠くありません。
これから配列を取得するには、2番目のパラメーターをtrueに設定します。そうしないと、代わりにオブジェクトを取得します。
json_decode($jsondata, true);
私の機能もクールだと思います、ネストされた配列で動作します:
function print_r_reverse($input)
{
$output = str_replace(['[', ']'], ["'", "'"], $input);
$output = preg_replace('/=> (?!Array)(.*)$/m', "=> '$1',", $output);
$output = preg_replace('/^\s+\)$/m', "),\n", $output);
$output = rtrim($output, "\n,");
return eval("return $output;");
}
注意:ユーザー入力データでこれを使用しない方が良い
使用する
var_export(array('Sample array', array('Apple', 'Orange')));
出力:
array (
0 => 'Sample array',
1 =>
array (
0 => 'Apple',
1 => 'Orange',
),
)
クイック機能(適切なデータを送信しているかどうかのチェックなし):
function textToArray($str)
{
$output = [];
foreach (explode("\n", $str) as $line) {
if (trim($line) == "Array" or trim($line) == "(" or trim($line) == ")") {
continue;
}
preg_match("/\[(.*)\]\ \=\>\ (.*)$/i", $line, $match);
$output[$match[1]] = $match[2];
}
return $output;
}
これは予想される入力です。
Array
(
[test] => 6
)