Skip to main content

Create XML and write to file


 static void WriteXml(Args _args)  
 {  
 XmlDocument xmlDoc;  
 XmlElement xmlRoot;  
 XmlElement xmlField;  
 XmlElement xmlRecord;  
 XMLWriter xmlWriter;  
 CarTable carTable;  
 DictTable dTable = new DictTable(tablenum(CarTable));  
 DictField dField;  
 int i, fieldId;  
 str value;  
 #CarsXmlTags  
 ;  
 // Create a new object of the XmlDocument class  
 xmlDoc = XmlDocument::newBlank();  
 // Create the root node  
 xmlRoot = xmlDoc.createElement(#CarRootNode);  
 // Loop through all the records in the carTable  
 while select carTable  
 {  
 // Create a XmlElement (record) to hold the  
 // contents of the current record.  
 xmlRecord = xmlDoc.createElement(#CarRecords);  
 // Loop through all the fields in the record  
 for (i=1; i<=dTable.fieldCnt(); i++)  
 {  
 // Get the fieldId from the field-count  
 fieldId = dTable.fieldCnt2Id(i);  
 // Find the DictField object that matches  
 // the fieldId  
 dField = dTable.fieldObject(fieldId);  
 // Skip system fields  
 if (dField.isSystem())  
 continue;  
 // Create a new XmlElement (field) and  
 // have the name equal to the name of the  
 // dictField  
 xmlField = xmlDoc.createElement(dField.name());  
 // Convert values to string. I have just added  
 // a couple of conversion as an example.  
 // Use tableName.(fieldId) instead of fieldname  
 // to get the content of the field.  
 switch (dField.baseType())  
 {  
 case Types::Int64 :  
 value = int642str(carTable.(fieldId));  
 break;  
 case Types::Integer :  
 value = int2str(carTable.(fieldId));  
 break;  
 default :  
 value = carTable.(fieldId);  
 break;  
 }  
 // Set the innerText of the XmlElement (field)  
 // to the value from the table  
 xmlField.innerText(value);  
 // Append the field as a child node to the record  
 xmlRecord.appendChild(xmlField);  
 }  
 // Add the record as a child node to the root  
 xmlRoot.appendChild(xmlRecord);  
 }  
 // Add the root to the XmlDocument  
 xmlDoc.appendChild(xmlRoot);  
 // Create a new object of the XmlWriter class  
 // in order to be able to write the xml to a file  
 xmlWriter = XMLWriter::newFile(@"c:\temp\cars.xml");  
 // Write the content of the XmlDocument to the  
 // file as specified by the XmlWriter  
 xmlDoc.writeTo(xmlWriter);  

Popular posts from this blog

strScan and Find a first occurrence of a string in a string using x++

strScan (Find a first occurrence of a string in a string) info("int strScan(str _text1,str _text2,int _position,int _number)"); info("Searches a text string for the occurrence of another string."); info("_text1 - The text string to search."); info("_text2 - The string to find."); info("_position - The position at which the search should start."); info("_number - The number of characters that should be searched."); info(int2str(strScan("ABCDEFGHIJ","DE",1,10)));

Code to get customer Primary Address in Ax 2012

Below Code to get customer Primary Address in Ax 2012. CustTable custTable_P; DirPartyTable dirPartyTable_P; DirPartyLocation dirPartyLocation_P; DirPartyLocationRole dirPartyLocationRole_P; LogisticsLocation logisticsLocation_P; LogisticsLocationRole logisticsLocationRole_P; LogisticsPostalAddress logisticsPostalAddress_P; LogisticsPostalAddress primaryAddress_P; while select custTable_P where custTable_P.AccountNum =='ED_01029' join dirPartyTable_P where dirPartyTable_P.RecId == custTable_P.Party join dirPartyLocation_P where dirPartyLocation_P.Party == custTable_P.Party && dirPartyLocation_P.IsPrimary==NoYes::Yes join dirPartyLocationRole_P where dirPartyLocationRole_P.PartyLocation == dirPartyLocation_P.RecId join logisticsLocationRole_P where logisticsLocationRole_P.RecId == dirPartyLocationRole

Get record from table on the basis of field id in Microsoft dynamics axapta x++

How to Get record from table on the basis of field id in dynamics axapta x++. just try following code in job to understand better way. emplTable emplTable; FieldId fieldId; ; fieldId = fieldNum(emplTable, Emplid); select emplTable; info(emplTable.(fieldId)); select emplTable where emplTable.(fieldId) == '1101'; info(emplTable.Name);