我正在尝试从Array中检索值。这是代码:
$opt=get_records_sql($sql1);
print_object($opt);
$n = count($opt);
if (empty($opt)){
echo 'No options selected';
}
else{
$optno = $opt["subjectid"];
echo '<br>$optno = '.$optno;
}
我尝试使用:$opt["subjectid"]
但是我收到以下错误:
Notice: Undefined index: subjectid
数组内容:
Array
(
[1] => stdClass Object
(
[uname] => JHollands06
[tutor] => M LSt
[subjectid] => 1
[year] => 2010
[optid] => 1
)
)
如何获取值为1的数据subjectid?
答案 0 :(得分:9)
方法1:通过强制转换对象将其转换为数组。
$opt[1] = (array) $opt[1];
echo $opt[1]['subjectid'];
转换数组中的所有对象(如果有多个):
foreach ($opt as $k => $val) {
$opt[$k] = (array) $val;
}
方法2:只需将其称为已分配的对象。
echo $opt[1]->subjectid
数组和对象之间存在差异。对象包含必须使用' - &gt;'调用的变量并且数组包含与特定键关联的值。在输出状态中,您有一个包含stdClass对象的数组,而不是另一个数组。
答案 1 :(得分:1)
您的数组包含行。这不仅仅是一排。所以你需要先按行索引它。
编辑:你的行是对象,我的坏。所以它应该是
$opt[1]->subjectid
答案 2 :(得分:1)
$ opt是一个行数组。所以你会做这样的事情:
foreach($opt as $row)
{
echo $row['subjectid'];
}
或者只使用索引:
$opt[0]['subjectid'];