使用PHP导出到XML

时间:2017-03-08 19:56:39

标签: php sql xml export export-to-xml

尝试将以下PHP导出到XML,以便为Yealink SIP-T46G创建远程电话簿。管理到目前为止,但目前正在导出一种无法在手机上使用的XML格式。在整个网站上,我发现了类似的问题,但没有设法让这个工作。



<?php
include './data/datalogin.php';
$sql = mysqli_query($con,"SELECT contact_id, name, phone, cell FROM contact ORDER BY name ASC");
$xml = "<root_contact>";

while($r = mysqli_fetch_array($sql))
{
$xml .= "<contact>";
$xml .= $display_name=$r["name"];
$xml .= $office_number=$r["phone"];
$xml .= $mobile_number=$r["cell"];
$xml .= "</contact>";
}
$xml .= "</root_contact>";

$sxe = new SimpleXMLElement($xml);
$dom = new DOMDocument('1,0');
$dom->preserveWhiteSpace = false;
$dom->formatOutput = true;
$dom->loadXML($sxe->asXML());
echo $dom->saveXML();
$dom->save('phonebookt47.xml');
?>
&#13;
&#13;
&#13;

当前的输出格式为,只是在显示后立即添加电话号码,而不是下面所需的格式。

<contact>SampleCompany01666666666</contact>

需要以下列格式导出

<contact display_name="SampleCompanyName" office_number="01666666666" mobile_number="07945444444"/>

我不认为它很遥远,但感谢任何帮助。

3 个答案:

答案 0 :(得分:0)

您需要将属性放在content标记中,如下所示:

<?php
include './data/datalogin.php';
$sql = mysqli_query($con,"SELECT contact_id, name, phone, cell FROM contact ORDER BY name ASC");

$xml = "<root_contact>";

while($r = mysqli_fetch_array($sql))
{
   $xml .= '<contact display_name="'.$r["name"].'" office_number="'.$r["phone"].'" mobile_number="'.$r["cell"].'" />';
}

$xml .= "</root_contact>";

$sxe = new SimpleXMLElement($xml);
$dom = new DOMDocument('1,0');
$dom->preserveWhiteSpace = false;
$dom->formatOutput = true;
$dom->loadXML($sxe->asXML());

echo $dom->saveXML();

$dom->save('phonebookt47.xml');
?>

答案 1 :(得分:0)

您可以将SimpleXMLElementaddChild()addAttribute()

一起使用
<?php
$data = [
    ['id' => 1, 'name' => 'Contact One', 'phone' => '555555501', 'cell' => '999999901'],
    ['id' => 2, 'name' => 'Contact Two', 'phone' => '555555502', 'cell' => '999999902'],
    ['id' => 3, 'name' => 'Contact Three', 'phone' => '555555503', 'cell' => '999999903'],
];

$xml = new SimpleXMLElement('<root_contact/>');

foreach($data as $r) {
    $contact = $xml->addChild('contact');
    $contact->addAttribute('display_name', $r["name"]);
    $contact->addAttribute('office_number', $r["phone"]);
    $contact->addAttribute('mobile_number', $r["cell"]);
}

$dom = new DOMDocument('1.0');
$dom->preserveWhiteSpace = false;
$dom->formatOutput = true;
$dom->loadXML($xml->asXML());

header('Content-Type: text/xml');
echo $dom->saveXML();

//$dom->save('phonebookt47.xml');

答案 2 :(得分:0)

由于您将XML编写为连接字符串,因此您只需确保包含所有静态文本。看起来应该是这样的:

  $xml .= '<contact display_name="' . $r["name"] . '"office_number="' . $r["cell"] . '" mobile_number="' . $r["cell"] . '"/>';
}

编辑:只需将您的字符串文件作为文本转储到文件中。这消除了设备支持SimpleXMLElement功能的需要。

性能注意:我故意将其压缩成一行,因为每次使用 $ xml。= 时,它都会重新加载整个xml字符串以附加下一个参数。如果使用大型XML,这可能会显着降低您的速度。

如果这仍然太慢,你甚至可能想要创建一个兑现变量,在将它们写入xml字符串之前一次存储多个条目。