{"id":706,"date":"2024-02-04T15:18:16","date_gmt":"2024-02-04T07:18:16","guid":{"rendered":"https:\/\/live-d365fo.pantheonsite.io\/?p=706"},"modified":"2024-02-04T15:18:30","modified_gmt":"2024-02-04T07:18:30","slug":"how-to-import-excel-in-d365fo","status":"publish","type":"post","link":"https:\/\/live-d365fo.pantheonsite.io\/how-to-import-excel-in-d365fo\/","title":{"rendered":"\u5982\u4f55\u5728D365FO\u5bfc\u5165Excel\u6587\u4ef6(How to import EXCEL using X++ in D365 FO)"},"content":{"rendered":"\n
\nUsing System.IO;\nUsing OfficeOpenXml;\nUsing OfficeOpenXml.ExcelPackage;\nUsing OfficeOpenXml.ExcelRange;\n<\/pre>\n\n\n\n\u9664\u4e86\u57fa\u672c\u7684\u5305\uff0c\u6211\u4eec\u8fd8\u9700\u8981\u53c2\u8003\u5305:Directory<\/strong><\/p>\n\n\n\n
<\/figure>\n\n\n\n\u7b2c\u4e00\u90e8\u5206\u4ee3\u7801<\/h2>\n\n\n\n
\u5728\u8fd9\u90e8\u5206\u4ee3\u7801\u4e2d\uff0c\u521b\u5efa\u4e86\u4e00\u4e2a\u5bfc\u5165\u5bf9\u8bdd\u6846\uff0c\u5728\u8fd9\u91cc\u6211\u4eec\u53ef\u4ee5\u9009\u62e9\u9700\u8981\u5bfc\u5165\u7684\u6587\u4ef6\uff0c\u6587\u4ef6\u4e0a\u4f20\u4e4b\u540e\u4f1a\u88ab\u5b58\u50a8\u5728\u4e34\u65f6\u7684\u7a7a\u95f4\u4e2d<\/p>\n\n\n\n
<\/figure>\n\n\n\n<\/a>\u7b2c\u4e8c\u90e8\u5206\u4ee3\u7801<\/h2>\n\n\n\n\u5728\u8fd9\u90e8\u5206\u4ee3\u7801\u4e2d\uff0c\u6211\u4eec\u4ece\u5bfc\u5165\u7684Excel\u4e2d\u83b7\u53d6\u6570\u636e<\/p>\n\n\n\n
<\/figure>\n\n\n\n\u5b8c\u6574\u7684\u4ee3\u7801<\/a><\/h2>\n\n\n\n\nUsing System.IO;\nUsing OfficeOpenXml;\nUsing OfficeOpenXml.ExcelPackage;\nUsing OfficeOpenXml.ExcelRange;\nclass RunnableClass1\n{\n \/\/\/ \n \/\/\/ Runs the class with the specified arguments.\n \/\/\/ <\/summary>\n \/\/\/ The specified arguments.<\/param>\n public static void main(Args _args)\n {\n \/*---------part 1 ------------------*\/\n System.IO.Stream stream;\n ExcelSpreadsheetName sheet;\n FileUploadBuild fileUpload,fileUploadBuild;\n DialogGroup dialogUploadGroup;\n FormBuildControl formBuildControl;\n Dialog dialog=new Dialog(\"Excel Import Example\");\n dialogUploadGroup=dialog.addGroup(\"@SYS54759\");\n formBuildControl=dialog.formBuildDesign().control(dialogUploadGroup.name());\n fileUploadBuild=formBuildControl.addControlEx(classStr(fileUpload),\"UploadExcel\");\n fileUploadBuild.style(FileUploadStyle::MinimalWithFilename);\n fileUploadBuild.fileTypesAccepted(\".xlsx\");\n if(dialog.run() && dialog.closedOk())\n {\n FileUpload fileUploadControl=dialog.formRun().control(dialog.formRun().controlId(\"Upload\"));\n FileUploadTemporaryStorageResult\n fileUploadResult=file::GetFileFromUser(classStr(FileUploadTemporaryStorageStrategy));\n \/\/fileUploadResult=fileUploadControl.getFileUploadResult();\n \/*------------------part 1 end---------------------*\/\n \/*------------------part 2---------------------*\/\n if(fileUploadResult!= null && fileUploadResult.getUploadStatus())\n {\n stream=fileUploadResult.openResult();\n using(ExcelPackage package= new ExcelPackage(stream))\n {\n int rowCount, iterator;\n package.Load(stream);\n ExcelWorksheet worksheet= package.get_workbook().get_worksheets().get_Item(1);\n OfficeOpenXml.ExcelRange range=worksheet.Cells; \n rowCount = worksheet.Dimension.End.Row - worksheet.Dimension.Start.Row + 1;\n for(iterator=2;iterator<=rowCount;iterator++)\n {\n Info(range.get_Item(iterator,1).Value);\n Info(range.get_Item(iterator,2).Value);\n Info(range.get_Item(iterator,3).Value);\n }\n }\n }\n \/*------------------part 2 end---------------------*\/\n }\n else\n {\n Error(\"error occured.\");\n }\n }\n}\n<\/pre>\n\n\n\n\u5bfc\u5165<\/h2>\n\n\n\n
\u8fd0\u884c\u4e0a\u9762\u7684Job\u4e4b\u540e\uff0c\u7cfb\u7edf\u4f1a\u5f39\u51fa\u5bfc\u5165\u5bf9\u8bdd\u6846\uff0c\u7136\u540e\u9009\u62e9\u4e0b\u9762\u7684\u6587\u4ef6\u3002<\/p>\n\n\n\n
<\/figure>\n\n\n\n
<\/figure>\n\n\n\n
<\/a><\/figure>\n\n\n\n\u4ee5\u4e0b\u662f\u70b9\u51fb\u201cOK\u201d\u4e4b\u540e\u7684\u7ed3\u679c\uff1a<\/p>\n\n\n\n
<\/figure>\n\n\n\n