|
17.01.2011, 20:12 | #1 |
Участник
|
Shekhar: Dynamics AX 2009 – Import fixed asset journal lines for posting accumulated depreciation
Источник: http://shekhardiptiman.spaces.live.c...B978!349.entry
============== During the implementation for importing the fixed asset transaction we need to post the acquisition journals and their accumulated depreciation as of the cut-off date. This is done by creating a Fixed asset journal and then importing the data in the journal lines for that journal. In AX 2009, the structure of the fixed asset journal transaction has been made a little complex than the earlier versions of the product and hence the data import through standard excel import using the definition groups. The following way may be followed to import the fixed asset journal lines in an efficient way. Step 1 . Create the import job in your AOT. I am copying the job code as below for use by the AX consultants. Copy it and paste it in jobs in your AOT. static void TEC_FixedAssetJournal_Insert(Args _args) { #define.ioComma(",") #define.ioEndLine("\r\n") #define.ioRead("r") AsciiIo io ; str jourName; str jourNum; str lineNum; str accountType; str accountNum; str amount; str currencyCode; str offsetAcType; str transdate; str offAc; str valMod; str assetype; // this is the transaction type str transtxt; int linecount; LedgerJournalTrans ledgerJournalTrans; LedgerJournalTrans_Asset ledgerJournalTrans_asset; LedgerJournalACType ledgerJournalACType; NumberSeq numSeq; int n = 1,idx =1; SysOperationProgress lprogress; #AviFiles ; io = new AsciiIo("\\\\AX-SRv-01\\DynamicsVM\\FileAccess\\CSVFile.txt", #ioRead); // This is the network path where the data file will be read from if(!io) error ("File cannot be open"); lprogress = new SysOperationProgress(); lprogress.setCaption("Insert Fixed asset trans "); lprogress.setAnimation(#AviUpdate); if (io) { io.inFieldDelimiter(#ioComma); io.inRecordDelimiter(#ioEndLine); [jourName, jourNum, transdate, accountNum, amount ,currencyCode, offsetAcType, offAc, transtxt, assetype, valMod] = io.read(); while (io.status() == IO_Status::Ok) { if (io.status() != IO_Status::Ok) { error("File not found"); } lprogress.setCount(n,Idx); lprogress.setText("Inserting trans"); n++; Idx++; numSeq = NumberSeq::newGetVoucherFromCode(LedgerJournalName::find(jourName).VoucherSeries, true ); if(!numSeq) error(strfmt("Number sequence set up does not exists for journal %1",jourName)); ledgerJournalTrans.Voucher = numSeq.voucher(); ledgerJournalTrans.TransDate = mkdate( str2int( substr( transdate, 1, 2 ) ), str2int( substr( transdate, 3, 2 ) ), str2int( substr( transdate, 5, 4 ) ) ); ledgerJournalTrans.JournalNum = jourNum; ledgerJournalTrans.LineNum = str2num(lineNum); ledgerJournalTrans.Company = curext(); ledgerJournalTrans.txt = transtxt; ledgerJournalTrans.AccountType = LedgerJournalACType::FixedAssets; ledgerJournalTrans.AccountNum = accountNum; if(str2num(amount) > 0) ledgerJournalTrans.AmountCurDebit = str2num(amount); else ledgerJournalTrans.AmountCurCredit = str2num(amount); ledgerJournalTrans.currencyCode = currencyCode; ledgerJournalTrans.ExchRate = Currency::exchRate(ledgerJournalTrans.currencyCode); switch (offsetAcType) { case "L" : ledgerJournalTrans.OffsetAccountType = LedgerJournalACType::Ledger; break; case "B" : ledgerJournalTrans.OffsetAccountType = LedgerJournalACType::Bank; break; case "C" : ledgerJournalTrans.OffsetAccountType = LedgerJournalACType::Cust; break; case "V" : ledgerJournalTrans.OffsetAccountType = LedgerJournalACType::Vend; break; case "F" : ledgerJournalTrans.OffsetAccountType = LedgerJournalACType::FixedAssets; break; default: ledgerJournalTrans.AccountType = LedgerJournalACType::Ledger; break; } ledgerJournalTrans.OffsetAccount = offAc; ledgerJournalTrans.insert(); if(ledgerJournalTrans.RecId) { ledgerJournalTrans_asset.RefRecId = ledgerJournalTrans.RecId; ledgerJournalTrans_asset.AssetId = ledgerJournalTrans.getAssetId(); ledgerJournalTrans_Asset.Company = ledgerJournalTrans.getAssetCompany(); ledgerJournalTrans_asset.BookId = valMod; if(assetype == "A") ledgerJournalTrans_asset.TransType = AssetTransTypeJournal::Acquisition; else ledgerJournalTrans_asset.TransType = AssetTransTypeJournal::Depreciation; ledgerJournalTrans_asset.insert(); } [jourName, jourNum, transdate, accountNum, amount ,currencyCode, offsetAcType, offAc, transtxt, assetype, valMod] = io.read(); } } } Step 2 : Now create a network folder which has been mentioned in the job in step 1 and give the full access to the windows user account which is using the job. For making it simple you may give the full access to ‘Everyone’. see the example structure below : See the properties set for the file CSVFile.txt in the screenshot below . Also enabling the sharing the folder containing the file. See the sharing and security properties for the folder ‘FileAccess’ as shown below. Step 3 ; Open a MS Excel file and populate the journal lines data in the columns in the following format : Save the file as .csv file e.g. CSVFile.csv. The highlighted row is for your information and understanding only . After the data is maintained in excel , pls delete the highlighted row #1. Step 4. Open the .csv file in the note pad. Save it at the same location as a flat file with .txt extension . e.g. CSVFile.txt Step 5 : All is done . now go back to AX and run the job. Step 6 : verify that the data is imported and visible in the journal lines . Recheck the amounts and post If you like this post or need any more information then leave your comments . enjoy Источник: http://shekhardiptiman.spaces.live.c...B978!349.entry
__________________
Расскажите о новых и интересных блогах по Microsoft Dynamics, напишите личное сообщение администратору. |
|
|
|