PHP 追加到 ClientDataSet CDS 文件


PHP append to ClientDataSet CDS File

我有一个空的Delphi ClientDataSet CDS文件设置,其中包含我需要的所有列/标题/数据类型。我想使用 PHP 将关联数组附加到 CDS 行中。这可能吗?

数组可以简单地是:

{
    1: {Name:Captain, Phone:18001234567}
    2: {Name:Jack, Phone:18009876543}
    3: {Name:Sparrow, Phone:18887892345}
}

我选择了PHP,因为我精通该语言,并且我的Web服务器是共享Linux主机。基本上我不能在这里运行德尔福。我对可以在这种环境中工作的其他选项持开放态度。谢谢!

编辑:

请参阅这篇文章的评论以了解我的解决方案。

我建议您不要直接写入cds文件。

相反,您可以为两个应用程序(PHP和Delphi)使用通用xml,在delphi端,您可以使用带有TXmlTransformProvider的XML Transformation加载并保存它,而在PHP端,您只需像往常一样将其写入XML。

看看这里如何设置德尔福。

--更新

如果您确实需要直接更改cds文件(使用xml格式),则可以在cds文件中添加新的,考虑到cds格式是xml,如下所示:

<?xml version="1.0" standalone="yes"?>  
<DATAPACKET Version="2.0">
    <METADATA>
        <FIELDS>
            <FIELD attrname="Name" fieldtype="string" WIDTH="24"/>
            <FIELD attrname="Capital" fieldtype="string" WIDTH="24"/>            
        </FIELDS>
        <PARAMS DEFAULT_ORDER="1" PRIMARY_KEY="1" LCID="2057"/>
    </METADATA>
    <ROWDATA>
        <ROW Name="Argentina" Capital="Buenos Aires"/>
        <ROW Name="Bolivia" Capital="La Paz"/>
        <ROW Name="Brazil" Capital="Brasilia"/>
        <ROW Name="Canada" Capital="Ottawa"/>        
        <ROW Name="United States of America" Capital="Washington"/> 
        //Add your new ROW tag here with your data       
    </ROWDATA>
</DATAPACKET>