数组名称中的大括号变量,PHP

Curly brace variable in array name, PHP

提问人:user3523624 提问时间:4/11/2014 更新时间:4/11/2014 访问量:615

问:

我知道这里有很多类似的问题,我想我已经把它们都读过了。我的问题是我试图遍历数组列表并从每个数组中获取一个值。阵列已由第三方设置,我无权配置接收它们的方式。这是我到目前为止所拥有的:

for ($i = 0; $i < $length; $i++) {

    // Both of these work and return the value I need
    echo $post->related_credits_0_related_show[0]; 
    echo "{$post->related_credits_0_related_show[0]}"

    // But none of these do, and I need to loop through a handful of arrays
    echo "{$post->related_credits_{$i}_related_show[0]}";
    echo "{$post->related_credits_${i}_related_show[0]}";
    echo "{$post->related_credits_{${i}}_related_show[0]}";
    echo "{$post->related_credits_".$i."_related_show[0]}";

}

我已经尝试了很多(很多!)更多的组合,我不会包括。我还尝试将$i转换为字符串。一段时间以来一直在敲我的头。

提前感谢您的任何帮助。

PHP 数组 变量

评论

0赞 Awlad Liton 4/11/2014
eval.in/135417

答:

2赞 hek2mgl 4/11/2014 #1

您可以使用以下功能:

$varname = "related_credits_$i_related_show";
$array =  $post->$varname;
echo $array[0]; 

较短的形式是:

$post->{"related_credits_{$i}_related_show"}[0];

在这里,您可以找到所有关于所谓的“变量”的信息:http://www.php.net/manual/en/language.variables.variable.php

评论

0赞 user3523624 4/11/2014
这几乎通过一次编辑就做到了,我不得不在$i周围戴上大括号。Stackoverflow 会让我在 3 分钟内接受答案,谢谢你这么快!
0赞 hek2mgl 4/11/2014
是的。我还添加了一个缩短的替代方案。
5赞 Amal Murali 4/11/2014 #2

您需要在此处使用变量。基本用法如下:

$var = 'Hello there!';
$foo = 'var';
echo $$foo;
     ^^--- note the double $-sign

这将输出:

Hello there!

代替 ,您还可以编写以下内容:$$foo

echo ${"$foo"};

如果变量名称比较复杂,还可以执行以下操作:

echo ${"some_stuff_{$foo}_more_stuff"};

在本例中,表示变量名称的字符串包含一个变量,并且该变量也包含在大括号 () 内。这样做是为了避免常量、数组索引等问题。但是,如果您的用例不涉及其中任何一个,则不必担心。{}

对于您的特定问题,您可以使用以下命令:

for ($i=0; $i < $length; $i++) { 
    $post->{"related_credits_{$i}_related_show"}[0];
}

或者,如果您更喜欢串联:

for ($i=0; $i < $length; $i++) { 
    $res = $post->{'related_credits_'.$i.'_related_show'}[0];
}

有关更多信息,请参阅有关变量的文档

评论

0赞 N.B. 4/11/2014
您的示例没问题,但有一个小错误 - 即评估将发生在 而不是 并且错误将是有一个未定义的变量 '。但是,+1 是一个很好的例子。$i_related_show$i$i_related_show
0赞 Amal Murali 4/11/2014
@N.B.:啊,对。在发布之前,我没有测试过这一点。现已修复 :)
0赞 Vishal Kumar Sahu 10/21/2018
我发现包含$xyz{26}等的黑客文件,可以解释吗?