有没有办法将 Azure 表存储实体转换为 JSON?
PHP 中的 Azure Entity 对象有很多元数据。有没有一种清理它的好方法,并返回一个仅包含相关数据的 JSON 对象。
实体对象打印出类似这样的内容
WindowsAzure\Table\Models\Entity Object
(
[_etag:WindowsAzure\Table\Models\Entity:private] => W/"datetime'2013-10-07T04%3A19%3A37.0155205Z'"
[_properties:WindowsAzure\Table\Models\Entity:private] => Array
(
[PartitionKey] => WindowsAzure\Table\Models\Property Object
(
[_edmType:WindowsAzure\Table\Models\Property:private] =>
[_value:WindowsAzure\Table\Models\Property:private] => weather
)
[RowKey] => WindowsAzure\Table\Models\Property Object
(
[_edmType:WindowsAzure\Table\Models\Property:private] =>
[_value:WindowsAzure\Table\Models\Property:private] => 0d625293-ef40-492b-bf07-d2889597a8f4
)
[Timestamp] => WindowsAzure\Table\Models\Property Object
(
[_edmType:WindowsAzure\Table\Models\Property:private] => Edm.DateTime
[_value:WindowsAzure\Table\Models\Property:private] => DateTime Object
(
[date] => 2013-10-07 04:19:37
[timezone_type] => 3
[timezone] => UTC
)
)
[type] => WindowsAzure\Table\Models\Property Object
(
[_edmType:WindowsAzure\Table\Models\Property:private] => Edm.Int32
[_value:WindowsAzure\Table\Models\Property:private] => 1
)
[city] => WindowsAzure\Table\Models\Property Object
(
[_edmType:WindowsAzure\Table\Models\Property:private] =>
[_value:WindowsAzure\Table\Models\Property:private] => Pune
)
[temperature] => WindowsAzure\Table\Models\Property Object
(
[_edmType:WindowsAzure\Table\Models\Property:private] => Edm.Int32
[_value:WindowsAzure\Table\Models\Property:private] => 34.7
)
[localTime] => WindowsAzure\Table\Models\Property Object
(
[_edmType:WindowsAzure\Table\Models\Property:private] =>
[_value:WindowsAzure\Table\Models\Property:private] => 2013-10-07T04:19:31.724Z
)
)
)
我想要一个像这样的干净的 JSON 输出
{
PartitionKey:"weather",
RowKey: "0d625293-ef40-492b-bf07-d2889597a8f4",
Timestamp: "2013-10-07 04:19:37"
type: 1,
city: "Pune",
tempterature: 34.7
localTime: "2013-10-07T04:19:31.724Z"
}
我已经实现了一个循环来实现这一点。我不确定这是否是最好的方法。
$entities = $result->getEntities();
$jsonArray = array();
for ($i = 0; $i < count($entities); $i++) {
$arr = $entities[$i]->getProperties();
$tempArr = array();
foreach ($arr as $key => $value) {
if(gettype($entities[$i]->getPropertyValue($key)) != 'object'){
$tempArr[$key] = (string)$entities[$i]->getPropertyValue($key); }
else
{
$tempArr[$key] = serialize($entities[$i]->getPropertyValue($key));
}
}
array_push($jsonArray, $tempArr);
}
echo json_encode($jsonArray);