Friday, 12 April 2013
AX 2009 : Read CSV file in x++
static void ReadCSVFile(Args _args)
{
Dialog dialog;
DialogField dialogFileName;
SysOperationProgress simpleProgress;
Filename filename;
CommaIo csvFile;
container readCon;
Container filterCriteria;
int numLines;
int cnt;
FileIOPermission permission;
TextIO textIO;
Str _taskStat;
SugarRecordId _sugarRecId; //field variable
PaymSchedule _paymentSchedule; // Table instance
PaymScheduleHistory _paymScheduleHistory; //Table instance
textBuffer tb = new textBuffer();
#File
#avifiles
;
//salesTable = _args.record();
dialog = new Dialog("Importing Text File");
dialogFileName = dialog.addField(typeid(Filenameopen), "File Name");
filterCriteria = ['*.csv'];
filterCriteria = dialog.filenameLookupFilter(filterCriteria);
dialog.run();
if (dialog.run())
filename = dialogFileName.value();
if(!filename)
{
info("Filename must be filled");
throw(" ");
}
permission = new fileIOpermission(filename,#io_read);
permission.assert();
textIO = new TextIO(filename,#io_read);
if (!textIO)
{
throw error("Error reading file");//@ABC4");
}
tb.fromFile(filename);//File name with Path ...
numLines = tb.numLines();
csvFile = new CommaIo(filename, 'r');
csvFile.inFieldDelimiter(" "); // Delimiter...
simpleProgress = SysOperationProgress::newGeneral(#aviUpdate, 'Importing data'/*@ABC5'*/,1000);
if (csvFile)//Checking for csv file.
{
readCon = csvFile.read();//reading the file.
ttsbegin;
for(cnt=1;cnt<=numLines;cnt++)
{
readCon = str2Con(tb.nextToken(true));
if(cnt>1)
{
_sugarRecId = conpeek(readCon,9);
_paymentSchedule = PwC_PaymSchedule::findBySugarRecId(_sugarRecId);
_paymScheduleHistory = AUR_PaymScheduleHistory::findBySugarRecId(_sugarRecId);
if(_paymentSchedule)
{
delete_from _paymentSchedule where _paymentSchedule.SugarRecordId == _sugarRecId;
}
if(_paymScheduleHistory)
{
select forupdate _paymScheduleHistory where _paymScheduleHistory.SugarRecordId == _sugarRecId;
_paymScheduleHistory.SugarRecordId = _sugarRecId;
_paymScheduleHistory.SalesId = conpeek(readCon,1);
_paymScheduleHistory.PaymMode = conpeek(readCon,2);
_paymScheduleHistory.PaymReference = conpeek(readCon,3);
_paymScheduleHistory.InstrumentDate = str2date(conpeek(readCon,4),213);
_paymScheduleHistory.InstrumentCurrencyCode = conpeek(readCon,5);
_paymScheduleHistory.InstrumentAmount = conpeek(readCon,6);
_paymScheduleHistory.BankDetails = conpeek(readCon,7);
//_paymScheduleHistory.dataAreaId = conpeek(readCon,8);
_paymScheduleHistory.Accepted = conpeek(readCon,10);
_paymScheduleHistory.ClearedAmount = conpeek(readCon,11);
_paymScheduleHistory.ClearanceStatus = conpeek(readCon,12);
_paymScheduleHistory.PaymType = conpeek(readCon,14);
_paymScheduleHistory.PaymId = conpeek(readCon,15);
_paymScheduleHistory.Remarks = conpeek(readCon,16);
_paymScheduleHistory.AUR_Reason = conpeek(readCon,17);
_paymScheduleHistory.update();
_taskStat = strfmt("History updated");
}
else if(_paymentSchedule && !_paymScheduleHistory)
{
//_paymScheduleHistory.SugarRecordId = _sugarRecId;
_paymScheduleHistory.SalesId = conpeek(readCon,1);
_paymScheduleHistory.PaymMode = conpeek(readCon,2);
_paymScheduleHistory.PaymReference = conpeek(readCon,3);
_paymScheduleHistory.InstrumentDate = str2date(conpeek(readCon,4),213);
_paymScheduleHistory.InstrumentCurrencyCode = conpeek(readCon,5);
_paymScheduleHistory.InstrumentAmount = conpeek(readCon,6);
_paymScheduleHistory.BankDetails = conpeek(readCon,7);
//_paymScheduleHistory.dataAreaId = conpeek(readCon,8);
_paymScheduleHistory.SugarRecordId = _sugarRecId;
_paymScheduleHistory.Accepted = conpeek(readCon,10);
_paymScheduleHistory.ClearedAmount = conpeek(readCon,11);
_paymScheduleHistory.ClearanceStatus = conpeek(readCon,12);
_paymScheduleHistory.PaymType = conpeek(readCon,14);
_paymScheduleHistory.PaymId = conpeek(readCon,15);
_paymScheduleHistory.Remarks = conpeek(readCon,16);
_paymScheduleHistory.AUR_Reason = conpeek(readCon,17);
_paymScheduleHistory.insert();
_taskStat = strfmt("History inserted");
}
//info(_paymentSchedule.SugarRecordId);
}
}
info(_taskStat);
ttscommit;
}
}
Subscribe to:
Post Comments (Atom)
No comments:
Post a Comment