Using X++ code create and Read XML file.
As in Dynamics AX 2009, XML is widely used , so I got a code which will help to create XML file.
static void Jimmy_CreateXMLFile(Args _args)
{
//As in Dynamics AX 2009, XML is widely used , so I got a code which will help to create XML file.
XmlDocument doc;
XmlElement nodeXml;
XmlElement nodeTable;
XmlElement nodeAccount;
XmlElement nodeName;
LedgerTable ledgerTable;
filename filename;
int i;
#WinAPI
;
doc = XmlDocument::newBlank();
nodeXml = doc.createElement('xml');
doc.appendChild(nodeXml);
while select ledgerTable order by ledgerTable.AccountNum
{
i++;
nodeTable = doc.createElement(tablestr(LedgerTable));
nodeTable.setAttribute(fieldstr(LedgerTable, RecId),int642str(ledgerTable.RecId));
nodeXml.appendChild(nodeTable);
nodeAccount = doc.createElement(fieldstr(LedgerTable, AccountNum));
nodeAccount.appendChild(doc.createTextNode(ledgerTable.AccountNum));
nodeTable.appendChild(nodeAccount);
nodeName = doc.createElement(fieldstr(LedgerTable, AccountName));
nodeName.appendChild(doc.createTextNode(ledgerTable.AccountName));
nodeTable.appendChild(nodeName);
if(i == 5)
break;
}
filename = WinAPI::getFolderPath(#CSIDL_PERSONAL);
filename += '\\accounts.xml';
doc.save(filename);
info("Finished!");
}
{
//As in Dynamics AX 2009, XML is widely used , so I got a code which will help to create XML file.
XmlDocument doc;
XmlElement nodeXml;
XmlElement nodeTable;
XmlElement nodeAccount;
XmlElement nodeName;
LedgerTable ledgerTable;
filename filename;
int i;
#WinAPI
;
doc = XmlDocument::newBlank();
nodeXml = doc.createElement('xml');
doc.appendChild(nodeXml);
while select ledgerTable order by ledgerTable.AccountNum
{
i++;
nodeTable = doc.createElement(tablestr(LedgerTable));
nodeTable.setAttribute(fieldstr(LedgerTable, RecId),int642str(ledgerTable.RecId));
nodeXml.appendChild(nodeTable);
nodeAccount = doc.createElement(fieldstr(LedgerTable, AccountNum));
nodeAccount.appendChild(doc.createTextNode(ledgerTable.AccountNum));
nodeTable.appendChild(nodeAccount);
nodeName = doc.createElement(fieldstr(LedgerTable, AccountName));
nodeName.appendChild(doc.createTextNode(ledgerTable.AccountName));
nodeTable.appendChild(nodeName);
if(i == 5)
break;
}
filename = WinAPI::getFolderPath(#CSIDL_PERSONAL);
filename += '\\accounts.xml';
doc.save(filename);
info("Finished!");
}
Using DataSet read XML file
static void Jimmy_DataSetReadXML(Args _args)
{
System.Data.DataSet DataSet;
System.Data.DataTableCollection DataTableCollection ;
System.Data.DataTable DataTable;
System.Data.DataRowCollection DataRowCollection;
System.Data.DataColumnCollection DataColumnCollection;
System.Data.DataRow DataRow;
System.Data.DataColumn DataColumn;
int i,j,TotalCol,TotalRow;
str _xml;
;
DataSet = new System.Data.DataSet();
DataSet.ReadXml(@"D:\My Documents\accounts.xml");
DataTableCollection = DataSet.get_Tables();
DataTable = DataTableCollection.get_Item(0);
DataColumnCollection = DataTable.get_Columns();//列
DataRowCollection = DataTable.get_Rows();//行
TotalRow = DataRowCollection.get_Count();//行数
TotalCol = DataColumnCollection.get_Count();//列数
for(i = 0; i < TotalRow; i ++)
{
DataRow = DataRowCollection.get_Item(i);
//setprefix(CLRInterop::getAnyTypeForObject(DataRow.get_Item(i)));
for(j = 0; j < TotalCol; j ++)
{
//DataRow = DataRowCollection.get_Item(i);
if (DataRow.IsNull(j))
_xml = 'null';
else
_xml = DataRow.get_Item(j);
info(strfmt("%1 - %2 - %3",i,j,_XML));
}
}
}
{
System.Data.DataSet DataSet;
System.Data.DataTableCollection DataTableCollection ;
System.Data.DataTable DataTable;
System.Data.DataRowCollection DataRowCollection;
System.Data.DataColumnCollection DataColumnCollection;
System.Data.DataRow DataRow;
System.Data.DataColumn DataColumn;
int i,j,TotalCol,TotalRow;
str _xml;
;
DataSet = new System.Data.DataSet();
DataSet.ReadXml(@"D:\My Documents\accounts.xml");
DataTableCollection = DataSet.get_Tables();
DataTable = DataTableCollection.get_Item(0);
DataColumnCollection = DataTable.get_Columns();//列
DataRowCollection = DataTable.get_Rows();//行
TotalRow = DataRowCollection.get_Count();//行数
TotalCol = DataColumnCollection.get_Count();//列数
for(i = 0; i < TotalRow; i ++)
{
DataRow = DataRowCollection.get_Item(i);
//setprefix(CLRInterop::getAnyTypeForObject(DataRow.get_Item(i)));
for(j = 0; j < TotalCol; j ++)
{
//DataRow = DataRowCollection.get_Item(i);
if (DataRow.IsNull(j))
_xml = 'null';
else
_xml = DataRow.get_Item(j);
info(strfmt("%1 - %2 - %3",i,j,_XML));
}
}
}
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步