當前位置: 首頁>>代碼示例>>C#>>正文


C# ExcelPackage.Load方法代碼示例

本文整理匯總了C#中OfficeOpenXml.ExcelPackage.Load方法的典型用法代碼示例。如果您正苦於以下問題:C# ExcelPackage.Load方法的具體用法?C# ExcelPackage.Load怎麽用?C# ExcelPackage.Load使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在OfficeOpenXml.ExcelPackage的用法示例。


在下文中一共展示了ExcelPackage.Load方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: GetDataTableFromExcel

 public static DataTable GetDataTableFromExcel(string path)
 {
     using (var pck = new ExcelPackage())
     {
         using (var stream = File.OpenRead(path))
         {
             pck.Load(stream);
         }
         var ws = pck.Workbook.Worksheets[0];
         var tbl = new DataTable();
         var cells = ws.Cells[1, 1, 1, ws.Dimension.End.Column];
         for (var i = cells.Start.Column; i <= cells.End.Column; i++)
         {
             tbl.Columns.Add(cells[1, i].Value.ToString());
         }
         for (var rowNum = 2; rowNum <= ws.Dimension.End.Row; rowNum++)
         {
             var wsRow = ws.Cells[rowNum, 1, rowNum, ws.Dimension.End.Column];
             var row = tbl.NewRow();
             for (var cellIndex = 1; cellIndex <= ws.Dimension.End.Column; cellIndex++)
             {
                 row[cellIndex - 1] = wsRow[rowNum, cellIndex].Value;
             }
             tbl.Rows.Add(row);
         }
         return tbl;
     }
 }
開發者ID:javess,項目名稱:eday,代碼行數:28,代碼來源:ExcelReader.cs

示例2: BeginProcessing

        protected override void BeginProcessing()
        {
            base.BeginProcessing();

            _ExcelPck = new ExcelPackage();

            var finalPath = this.CompileFinalPath();

            using (var stream = new FileStream(finalPath, FileMode.Open))
            {
                _ExcelPck.Load(stream);
            }
        }
開發者ID:scarmuega,項目名稱:ExcelCmdlets,代碼行數:13,代碼來源:ImportExcelCmdlet.cs

示例3: GetVendorUploadDetails

        public JsonResult GetVendorUploadDetails(string fileName, string type,string file)
        {
            System.Diagnostics.StackFrame stackFrame = new System.Diagnostics.StackFrame();
            System.Reflection.MethodBase methodBase = stackFrame.GetMethod();
            log.Debug("Start: " + methodBase.Name);

            string path = Path.Combine(Server.MapPath("~/VendorReportsExcelTemplate"), fileName);

            //var existingFile = new FileInfo(path);
            DataTable dtVendor = new DataTable();
            DataTable dtErrorRec = new DataTable();
            Vendor ObjVd = new Vendor();
            var VendorInfo = new VendorInfo();
            using (var pck = new OfficeOpenXml.ExcelPackage())
            {
                try
                {
                    var workBook = pck.Workbook;
                    if (workBook != null)
                    {
                        using (var stream = System.IO.File.OpenRead(path))
                        {
                            pck.Load(stream);
                        }
                        var currentWorksheet = pck.Workbook.Worksheets.First();

                        int Count=0; DataSet ds = new DataSet();
                        Count = ValidateExcel(type, currentWorksheet, Count, ds);
                        if (Count > 0)
                        {
                            string data = JsonConvert.SerializeObject(ds, Formatting.Indented);
                            return Json(data);
                        }

                        dtVendor = CreateVendorDataTable();
                        dtErrorRec = CreateErrorDataTable();
                        for (int rowNumber = ExcelStartRow + 1; rowNumber <= currentWorksheet.Dimension.End.Row; rowNumber++)
                        // read each row from the start of the data (start row + 1 header row) to the end of the spreadsheet.
                        {
                            //Column 4 : VendorRefNo    And     Column 5 : Amount    ARE MANDITORY
                            if (currentWorksheet.Cells[rowNumber, 4].Value != null && currentWorksheet.Cells[rowNumber, 5].Value != null)
                            {
                                try
                                {
                                    DataRow dr = dtVendor.NewRow();
                                    currentWorksheet.Cells[rowNumber, 1].Style.Numberformat.Format = "mm/dd/yyyy";
                                    dr["Date"] = (currentWorksheet.Cells[rowNumber, 1].Value == null ? DBNull.Value.ToString() : currentWorksheet.Cells[rowNumber, 1].Text);
                                    dr["UsedBy"] = (currentWorksheet.Cells[rowNumber, 2].Value == null ? DBNull.Value : currentWorksheet.Cells[rowNumber, 2].Value);
                                    dr["Description"] = (currentWorksheet.Cells[rowNumber, 3].Value == null ? DBNull.Value : currentWorksheet.Cells[rowNumber, 3].Value);
                                    dr["ReferenceNo"] = (currentWorksheet.Cells[rowNumber, 4].Value == null ? DBNull.Value : currentWorksheet.Cells[rowNumber, 4].Value);
                                    dr["Amount"] = (currentWorksheet.Cells[rowNumber, 5].Value == null ? DBNull.Value : currentWorksheet.Cells[rowNumber, 5].Value);
                                    dtVendor.Rows.Add(dr);
                                }
                                catch (Exception)
                                {
                                    DataRow dr = dtErrorRec.NewRow();
                                    currentWorksheet.Cells[rowNumber, 1].Style.Numberformat.Format = "mm/dd/yyyy";
                                    dr["Date"] = (currentWorksheet.Cells[rowNumber, 1].Value == null ? DBNull.Value.ToString() : currentWorksheet.Cells[rowNumber, 1].Text);
                                    dr["UsedBy"] = (currentWorksheet.Cells[rowNumber, 2].Value == null ? DBNull.Value : currentWorksheet.Cells[rowNumber, 2].Value);
                                    dr["Description"] = (currentWorksheet.Cells[rowNumber, 3].Value == null ? DBNull.Value : currentWorksheet.Cells[rowNumber, 3].Value);
                                    dr["ReferenceNo"] = (currentWorksheet.Cells[rowNumber, 4].Value == null ? DBNull.Value : currentWorksheet.Cells[rowNumber, 4].Value);
                                    dr["Amount"] = (currentWorksheet.Cells[rowNumber, 5].Value == null ? DBNull.Value : currentWorksheet.Cells[rowNumber, 5].Value);
                                    dtErrorRec.Rows.Add(dr);
                                }
                            }

                        }

                    }

                    ObjVd.dtvendor = dtVendor;
                    ObjVd.dtErrorRec = dtErrorRec;
                    ObjVd.RecordCount = dtVendor.Rows.Count;
                    ObjVd.Type = type;
                    ObjVd.Name = file;
                    string UserIDSession = Convert.ToString(System.Web.HttpContext.Current.Session["UserID"]);
                    bool checkForEmptyExcel = (dtVendor.Rows.Count == 0 && dtErrorRec.Rows.Count == 0) ? false : true;
                    if (!string.IsNullOrEmpty(UserIDSession))
                    {
                        if (checkForEmptyExcel)
                        {
                            ObjVd.UploadedBy = Convert.ToInt32(UserIDSession);
                            VendorInfo = ObjVd.InsertVendorRecords(ObjVd);
                        }
                    }
                }
                catch (Exception ex)
                {
                    log.Error("Error: " + ex);
                    VendorInfo.ExceptionMessage = "exception";
                }
                finally
                {
                    log.Debug("End: " + methodBase.Name);

                    if (System.IO.File.Exists(path))
                        System.IO.File.Delete(path);
                }
            }
            return Json(VendorInfo);
//.........這裏部分代碼省略.........
開發者ID:reddyjannavarapu,項目名稱:css3,代碼行數:101,代碼來源:VReportsController.cs

示例4: LoadWorkbookFromBytes

 public static ExcelWorkbook LoadWorkbookFromBytes(ExcelPackage package, byte[] bytes)
 {
     using (var stream = new MemoryStream(bytes)) {
         package.Load(stream);
         return package.Workbook;
     }
 }
開發者ID:coryrwest,項目名稱:CHABS,代碼行數:7,代碼來源:LoadSave.cs

示例5: Read_2007or2010

 private void Read_2007or2010()
 {
     try
     {
         FileStream stream;
         try
         {
             stream = new FileStream(txtTenFile.Text, FileMode.Open);
         }
         catch (Exception)
         {
             MessageBox.Show(FormResource.msgKiemTraFile, FormResource.MsgCaption, MessageBoxButtons.OK,
                 MessageBoxIcon.Information);
             ResultValue = null;
             return;
         }
         var excelPkg = new ExcelPackage();
         excelPkg.Load(stream);
         stream.Close();
         var oSheet = excelPkg.Workbook.Worksheets[1];
         var startRows = oSheet.Dimension.Start.Row + ViTriHeader;
         var endRows = oSheet.Dimension.End.Row;
         var maximum = (endRows - startRows + 1) > 100 ? (endRows - startRows + 1) : 200;
         upsbLoading.SetPropertyThreadSafe(p => p.Maximum, maximum);
         var donvi = (endRows - startRows + 1) == 0 ? maximum : maximum / (endRows - startRows + 1);
         for (var i = startRows; i <= endRows; i++)
         {
             _result.Rows.Add(
                 oSheet.Cells[i, 1].GetValue<string>(),
                 oSheet.Cells[i, 2].GetValue<string>(),
                 oSheet.Cells[i, 3].GetValue<string>(),
                 oSheet.Cells[i, 4].GetValue<string>(),
                 oSheet.Cells[i, 5].GetValue<string>()
                 );
            upsbLoading.SetPropertyThreadSafe(c => c.Value, (i - startRows + 1) * donvi);
         }
         upsbLoading.SetPropertyThreadSafe(c => c.Value, maximum);
         ResultValue = _result;
     }
     catch (Exception ex)
     {
        Log2File.LogExceptionToFile(ex);
        ResultValue = null;
     }
 }
開發者ID:khanhnqnuce,項目名稱:qlsv-khanhnq,代碼行數:45,代碼來源:FrmNDLSinhVien.cs

示例6: DeleteColumnAfterRangeLimitThrowsArgumentException

        public void DeleteColumnAfterRangeLimitThrowsArgumentException()
        {
            // Arrange
            ExcelPackage pck = new ExcelPackage();
            using (
                Stream file =
                    Assembly.GetExecutingAssembly()
                        .GetManifestResourceStream("EPPlusTest.TestWorkbooks.PreDeleteColumn.xls"))
            {
                pck.Load(file);
            }
            var wsData = pck.Workbook.Worksheets[1];

            // Act
            wsData.DeleteColumn(16385);

            // Assert
            Assert.Fail();

        }
開發者ID:acinep,項目名稱:epplus,代碼行數:20,代碼來源:WorksheetsTests.cs

示例7: GetListRows

        protected override List<ExcelProject> GetListRows(string fileName)
        {
            var stream = File.OpenRead(fileName);
            var excelPack = new ExcelPackage();
            excelPack.Load(stream);
            stream.Close();

            var listRows = new List<ExcelProject>();

            for (int i = 1; i <= excelPack.Workbook.Worksheets[1].Dimension.Rows; i++)
            {
                var structure = new ExcelProject();

                var dataRow = excelPack.Workbook.Worksheets[1].Cells[i, 1, i, 18];
                structure.Row = new object[18];
                for (int j = 0; j < 18; j++)
                {
                    structure.Row[j] = ((object[,])dataRow.Value)[0, j];
                }

                listRows.Add(structure);
            }

            return listRows;
        }
開發者ID:ctukc-nt,項目名稱:UPPY_v2,代碼行數:25,代碼來源:ExcelProjectLoader.cs

示例8: InvoiceFromCSS2

        public ActionResult InvoiceFromCSS2(string command)
        {
            try
            {
                if (command == "Sent To ACCPAC")
                {
                    #region Download

                    DataSet dsInvoice = Billing.GetCABPrepareInvoiceFromCSS2();
                    if (dsInvoice.Tables[0].Rows.Count > 0)
                    {
                        var fileName = "INVOICE_FROM_CSS2_" + DateTime.Now.ToString("yyyy-MM-dd--hh-mm-ss") + ".xlsx";

                        //var outputDir = HttpContext.Server.MapPath("~/CSS2ACCPACINTEGRATION/FromCSS2/");
                        //System.IO.FileInfo file = new FileInfo(outputDir + fileName);

                        string path = ConfigurationManager.AppSettings["AccpacFolderPath"].ToString() + "FromCSS2/";
                        System.IO.FileInfo file = new FileInfo(path + fileName);

                        using (var excely = new ExcelPackage(file))
                        {

                            #region WorkSheet 1

                            ExcelWorksheet worksheet = excely.Workbook.Worksheets.Add("INVOICE_FROM_CSS2");
                            //for Columns Names
                            worksheet.Cells[1, 1].LoadFromDataTable(dsInvoice.Tables[0], true);
                            //For Data
                            for (int i = 0; i < dsInvoice.Tables[0].Rows.Count; i++)
                            {
                                for (int j = 0; j < dsInvoice.Tables[0].Columns.Count; j++)
                                {
                                    string cellvalue = dsInvoice.Tables[0].Rows[i][j].ToString();
                                    worksheet.Cells[i + 2, j + 1].Value = cellvalue;
                                }
                            }

                            #endregion

                            #region Work Sheet 2

                            ExcelWorksheet worksheet1 = excely.Workbook.Worksheets.Add("INVOICE_DETAILS_FROM_CSS2");

                            //for Columns Names
                            worksheet1.Cells[1, 1].LoadFromDataTable(dsInvoice.Tables[1], true);
                            //For Data
                            for (int i = 0; i < dsInvoice.Tables[1].Rows.Count; i++)
                            {
                                for (int j = 0; j < dsInvoice.Tables[1].Columns.Count; j++)
                                {
                                    string cellvalue = dsInvoice.Tables[1].Rows[i][j].ToString();
                                    worksheet1.Cells[i + 2, j + 1].Value = cellvalue;
                                }
                            }

                            #endregion

                            #region Update SentStatus

                            string CABMasterIDs = string.Empty;

                            foreach (DataRow dr in dsInvoice.Tables[0].Rows)
                            {
                                CABMasterIDs += dr["CNTITEM"].ToString() + ",";
                            }

                            Billing.CABUpdateSentStatus(CABMasterIDs.TrimEnd(','));

                            #endregion

                            #region Invoice Log

                            string Direction = "InvoiceFromCSS2";
                            int InvoiceCount = dsInvoice.Tables[0].Rows.Count;
                            int DetailsCount = dsInvoice.Tables[1].Rows.Count;
                            int Result = Billing.InsertCABInvoiceLog(Direction, InvoiceCount, DetailsCount, fileName);

                            #endregion

                            excely.Save();
                            worksheet.Protection.IsProtected = true;
                            worksheet1.Protection.IsProtected = true;

                        }
                    }

                    #endregion
                }
                else if (command == "Read From ACCPAC")
                {
                    #region Read Excel

                    //var ExcelFiles = Directory.EnumerateFiles(HttpContext.Server.MapPath("~/CSS2ACCPACINTEGRATION/FromACCPAC/"), "*.xlsx");

                    string path = ConfigurationManager.AppSettings["AccpacFolderPath"].ToString() + "FromACCPAC/";
                    var ExcelFiles = Directory.EnumerateFiles(path, "*.xlsx");

                    foreach (string currentFile in ExcelFiles)
                    {
                        using (var pck = new ExcelPackage())
//.........這裏部分代碼省略.........
開發者ID:reddyjannavarapu,項目名稱:css3,代碼行數:101,代碼來源:BillingController.cs

示例9: ParseExcelStream2DataTable

        /// <summary>
        /// Load an xlsx Excel file into a datatable
        /// </summary>
        public static DataTable ParseExcelStream2DataTable(MemoryStream AStream,
            bool AHasHeader = false,
            int AWorksheetID = 0,
            List <string>AColumnsToImport = null)
        {
            ExcelPackage pck = new ExcelPackage();

            pck.Load(AStream);

            int countWorksheets = 0;
            ExcelWorksheet worksheet = null;

            foreach (ExcelWorksheet worksheetLoop in pck.Workbook.Worksheets)
            {
                if (countWorksheets == AWorksheetID)
                {
                    worksheet = worksheetLoop;
                }

                countWorksheets++;
            }

            DataTable result = new DataTable();

            if (worksheet == null)
            {
                return result;
            }

            List <string>ColumnNames = new List <string>();

            foreach (ExcelRangeBase firstRowCell in worksheet.Cells[1, 1, 1, worksheet.Dimension.End.Column])
            {
                string ColumnName = (AHasHeader ? firstRowCell.Text : string.Format("Column {0}", firstRowCell.Start.Column));
                ColumnNames.Add(ColumnName);

                if ((AColumnsToImport != null) && !AColumnsToImport.Contains(ColumnName))
                {
                    continue;
                }

                result.Columns.Add(ColumnName);
            }

            int firstDataRow = AHasHeader ? 2 : 1;

            for (int countRow = firstDataRow; countRow <= worksheet.Dimension.End.Row; countRow++)
            {
                ExcelRangeBase ExcelRow = worksheet.Cells[countRow, 1, countRow, worksheet.Dimension.End.Column];
                DataRow NewRow = result.NewRow();

                foreach (ExcelRangeBase cell in ExcelRow)
                {
                    if ((AColumnsToImport != null) && !AColumnsToImport.Contains(ColumnNames[cell.Start.Column - 1]))
                    {
                        continue;
                    }

                    NewRow[ColumnNames[cell.Start.Column - 1]] = cell.Value;
                }

                result.Rows.Add(NewRow);
            }

            return result;
        }
開發者ID:Davincier,項目名稱:openpetra,代碼行數:69,代碼來源:Csv2Xml.cs

示例10: OpenExcelFromByteArray

        private ExcelPackage OpenExcelFromByteArray()
        {
            try
            {
                ExcelPackage pck = new ExcelPackage();

                using (Stream stream = new MemoryStream(excelPackegInBytes))
                {
                    pck.Load(stream);
                    return pck;
                }

            }
            catch (Exception ex)
            {
                throw ex;
            }
        }
開發者ID:espressomorte,項目名稱:Supakull,代碼行數:18,代碼來源:ExcelAdapter.cs

示例11: DeleteFirstTwoColumnsFromRangeColumnsShouldBeDeleted

        public void DeleteFirstTwoColumnsFromRangeColumnsShouldBeDeleted()
        {
            // Arrange
            ExcelPackage pck = new ExcelPackage();
            using (
                Stream file =
                    Assembly.GetExecutingAssembly()
                        .GetManifestResourceStream("EPPlusTest.TestWorkbooks.PreDeleteColumn.xls"))
            {
                pck.Load(file);
            }
            var wsData = pck.Workbook.Worksheets[1];

            // Act
            wsData.DeleteColumn(1, 2);
            pck.SaveAs(new FileInfo(OutputDirectory + "AfterDeleteColumn.xlsx"));

            // Assert
            Assert.AreEqual("First Name", wsData.Cells["A1"].Text);
            Assert.AreEqual("Family Name", wsData.Cells["B1"].Text);

        }
開發者ID:acinep,項目名稱:epplus,代碼行數:22,代碼來源:WorksheetsTests.cs

示例12: ParseDataWorkSheet

        // This function will parse all data from a DB report worksheet to a DataTable object
        public static DataTable ParseDataWorkSheet(string Entry_id)
        {
            string fileName = null;
            using (spark1Entities db = new spark1Entities())
            {
                ReportEntries entry = db
                    .ReportEntries
                    .Where(re => re.EntryId == Entry_id)
                    .FirstOrDefault();

                fileName = Path.Combine(
                    HttpContext.Current.Server.MapPath("~/xls_reports"),
                    entry.EntryUser,
                    entry.EntryId + ".xlsx");
            }

            using (var pck = new OfficeOpenXml.ExcelPackage())
            {
                using (var stream = File.OpenRead(fileName))
                {
                    pck.Load(stream);
                }
                var ws = pck.Workbook.Worksheets["Data"];
                DataTable tbl = new DataTable();
                bool hasHeader = true;
                foreach (var firstRowCell in ws.Cells[1, 1, 1, ws.Dimension.End.Column])
                {
                    tbl.Columns.Add(hasHeader ? firstRowCell.Text : string.Format("Column {0}", firstRowCell.Start.Column));
                }
                var startRow = hasHeader ? 2 : 1;
                for (var rowNum = startRow; rowNum <= ws.Dimension.End.Row; rowNum++)
                {
                    var wsRow = ws.Cells[rowNum, 1, rowNum, ws.Dimension.End.Column];
                    var row = tbl.NewRow();
                    foreach (var cell in wsRow)
                    {
                        row[cell.Start.Column - 1] = cell.Text;
                    }
                    tbl.Rows.Add(row);
                }
                return tbl;
            }
        }
開發者ID:nesbo,項目名稱:spark,代碼行數:44,代碼來源:DBReportHelper.cs

示例13: ExcelImport

        public ExcelImportResponse ExcelImport(IUnitOfWork uow, ExcelImportRequest request)
        {
            request.CheckNotNull();
            Check.NotNullOrWhiteSpace(request.FileName, "filename");

            UploadHelper.CheckFileNameSecurity(request.FileName);

            if (!request.FileName.StartsWith("temporary/"))
                throw new ArgumentOutOfRangeException("filename");

            ExcelPackage ep = new ExcelPackage();
            using (var fs = new FileStream(UploadHelper.DbFilePath(request.FileName), FileMode.Open, FileAccess.Read))
                ep.Load(fs);

            var p = ProductRow.Fields;
            var s = SupplierRow.Fields;
            var c = CategoryRow.Fields;

            var response = new ExcelImportResponse();
            response.ErrorList = new List<string>();

            var worksheet = ep.Workbook.Worksheets[1];
            for (var row = 2; row <= worksheet.Dimension.End.Row; row++)
            {
                try
                {
                    var productName = Convert.ToString(worksheet.Cells[row, 1].Value ?? "");
                    if (productName.IsTrimmedEmpty())
                        continue;

                    var product = uow.Connection.TryFirst<ProductRow>(q => q
                        .Select(p.ProductID)
                        .Where(p.ProductName == productName));

                    if (product == null)
                        product = new ProductRow
                        {
                            ProductName = productName
                        };
                    else
                    {
                        // avoid assignment errors
                        product.TrackWithChecks = false;
                    }

                    var supplierName = Convert.ToString(worksheet.Cells[row, 2].Value ?? "");
                    if (!string.IsNullOrWhiteSpace(supplierName))
                    {
                        var supplier = uow.Connection.TryFirst<SupplierRow>(q => q
                            .Select(s.SupplierID)
                            .Where(s.CompanyName == supplierName));

                        if (supplier == null)
                        {
                            response.ErrorList.Add("Error On Row " + row + ": Supplier with name '" +
                                supplierName + "' is not found!");
                            continue;
                        }

                        product.SupplierID = supplier.SupplierID.Value;
                    }
                    else
                        product.SupplierID = null;

                    var categoryName = Convert.ToString(worksheet.Cells[row, 3].Value ?? "");
                    if (!string.IsNullOrWhiteSpace(categoryName))
                    {
                        var category = uow.Connection.TryFirst<CategoryRow>(q => q
                            .Select(c.CategoryID)
                            .Where(c.CategoryName == categoryName));

                        if (category == null)
                        {
                            response.ErrorList.Add("Error On Row " + row + ": Category with name '" +
                                categoryName + "' is not found!");
                            continue;
                        }

                        product.CategoryID = category.CategoryID.Value;
                    }
                    else
                        product.CategoryID = null;

                    product.QuantityPerUnit = Convert.ToString(worksheet.Cells[row, 4].Value ?? "");
                    product.UnitPrice = Convert.ToDecimal(worksheet.Cells[row, 5].Value ?? 0);
                    product.UnitsInStock = Convert.ToInt16(worksheet.Cells[row, 6].Value ?? 0);
                    product.UnitsOnOrder = Convert.ToInt16(worksheet.Cells[row, 7].Value ?? 0);
                    product.ReorderLevel = Convert.ToInt16(worksheet.Cells[row, 8].Value ?? 0);

                    if (product.ProductID == null)
                    {
                        new ProductRepository().Create(uow, new SaveWithLocalizationRequest<MyRow>
                        {
                            Entity = product
                        });

                        response.Inserted = response.Inserted + 1;
                    }
                    else
                    {
//.........這裏部分代碼省略.........
開發者ID:C-DUCK,項目名稱:Sningle,代碼行數:101,代碼來源:ProductExcelImportEndpoint.cs

示例14: LoadExcel

        /// <summary>
        /// 指定されたExcelを読み込み、Databaseに登録する
        /// </summary>
        /// <param name="path"></param>
        /// <param name="sheetName"></param>
        /// <param name="start_row"></param>
        /// <returns>Excel読み込みデータ</returns>
        public List<XlsData> LoadExcel(string path, string sheetName, int start_row)
        {
            log.Debug(string.Format("target file= {0}; sheet= {1}", path, sheetName));

            _start_row = start_row; //開始位置 (ログ出力に使用)
            int rowIndex = start_row;
            List<XlsData> records = new List<XlsData>();

            try
            {
                using (ExcelPackage xls = new ExcelPackage())
                {
                    using (FileStream fs = new FileStream(path, FileMode.Open))
                    {
                        xls.Load(fs);
                        ExcelWorksheet sheet = xls.Workbook.Worksheets[sheetName];

                        while (true)
                        {
                            XlsData data = new XlsData();

                            data.id = rowIndex - start_row;
                            // read row data
                            data.drcode = Utils.ParseString(sheet.Cells[rowIndex, 1].Value);
                            data.drname = Utils.ParseString(sheet.Cells[rowIndex, 2].Value);
                            if (string.IsNullOrEmpty(data.drname))
                            {
                                break; //Dr名が無ければ終了
                            }
                            data.ncc_cd = Utils.ParseString(sheet.Cells[rowIndex, 3].Value);
                            data.ncc_name = Utils.ParseString(sheet.Cells[rowIndex, 4].Value);
                            data.ncc_dept = Utils.ParseString(sheet.Cells[rowIndex, 5].Value);
                            data.title = Utils.ParseString(sheet.Cells[rowIndex, 6].Value);
                            data.category = Utils.ParseString(sheet.Cells[rowIndex, 7].Value);
                            data.kingaku = Utils.ParseLong(sheet.Cells[rowIndex, 8].Value);
                            data.kaisu = Utils.ParseInt(sheet.Cells[rowIndex, 9].Value);

                            // 頭 '0' 埋め
                            data.drcode = data.drcode.PadLeft(6, '0');
                            if (data.drcode == "000000")
                            {
                                data.drcode = string.Empty;
                            }

                            records.Add(data);
                            rowIndex++;
                        }

                    }
                }

                //読み込んだデータをDatabaseに登録
                int registed = BulkInsert(records);

                log.Info(string.Format("登録件數= {0}", registed));
            }
            catch (Exception exp)
            {
                log.Error(string.Format(@"Fatal Error.: {0}", rowIndex), exp);
            }

            return records;
        }
開發者ID:Kazunori-Kimura,項目名稱:LoadExcel,代碼行數:70,代碼來源:DataManager.cs

示例15: Import_To_Grid

    private void Import_To_Grid(string FilePath, string Extension, string isHDR)
    {
        if (Extension == ".xls")
        {
            //string notxlsx = ("This is not an xlsx file");
            //ClientScript.RegisterStartupScript(this.GetType(), "myalert", "alert('" + notxlsx + "');", true);

            HSSFWorkbook hssfworkbook;

            using (FileStream file = new FileStream(FilePath, FileMode.Open, FileAccess.Read))

                hssfworkbook = new HSSFWorkbook(file);

            ISheet sheet = hssfworkbook.GetSheetAt(0);
            System.Collections.IEnumerator rows = sheet.GetRowEnumerator();

            DataTable dt = new DataTable();

            //Counts the number of cells in a row and determines the columns from that.
            int counter = sheet.GetRow(0).Cells.Count;
            // J < number of columns needs to be exact at this moment
            for (int j = 0; j < counter; j++)
            {

                // set each column to a - ** letters
                // dt.Columns.Add(Convert.ToChar(((int)'A') + j).ToString());

                //Get first row and set the headers for each cell
                //dt.Columns.Add(Convert.ToString((string)sheet.GetRow(0).GetCell(+j).StringCellValue).ToString());
                //Get each cell value in row 0 and return its string for a column name.
                dt.Columns.Add(sheet.GetRow(0).GetCell(+j).StringCellValue);
            }

            while (rows.MoveNext())
            {
                HSSFRow row = (HSSFRow)rows.Current;
                DataRow dr = dt.NewRow();

                for (int i = 0; i < row.LastCellNum; i++)
                {
                    ICell cell = row.GetCell(i);

                    if (cell == null)
                    {
                        dr[i] = null;
                    }
                    else
                    {
                        dr[i] = cell.ToString();
                    }
                }
                dt.Rows.Add(dr);

            }
            //Hackish way to remove the bad first row made by getting column names
            dt.Rows.RemoveAt(0);
            GridView1.Caption = Path.GetFileName(FilePath);
            GridView1.DataSource = dt;
            //Bind the data
            GridView1.DataBind();
            sheet.Dispose();
            hssfworkbook.Dispose();

        }
        else
        {
            //Create a new epplus package using openxml
            var pck = new OfficeOpenXml.ExcelPackage();

            //load the package with the filepath I got from my fileuploader above on the button
            //pck.Load(new System.IO.FileInfo(FilePath).OpenRead());

            //stream the package
            FileStream stream = new FileStream(FilePath, FileMode.Open);
            pck.Load(stream);

            //So.. I am basicly telling it that there is 1 worksheet or to just look at the first one. Not really sure what kind of mayham placing 2 in there would cause.
            //Don't put 0 in the box it will likely cause it to break since it won't have a worksheet page at all.
            var ws = pck.Workbook.Worksheets[1];

            //This will add a sheet1 if your doing pck.workbook.worksheets["Sheet1"];
            if (ws == null)
            {
                ws = pck.Workbook.Worksheets.Add("Sheet1");
                // Obiviously I didn't add anything to the sheet so probably can count on it being blank.
            }

            //I created this datatable for below.
            DataTable tbl = new DataTable();

            //My sad attempt at changing a radio button value into a bool value to check if there is a header on the xlsx
            var hdr = bool.Parse(isHDR);
            Console.WriteLine(hdr);

            //Set the bool value for from above.
            var hasHeader = hdr;

            //Setup the table based on the value from my bool
            foreach (var firstRowCell in ws.Cells[1, 1, 1, ws.Dimension.End.Column])
            {
//.........這裏部分代碼省略.........
開發者ID:Kmcelyea,項目名稱:ExcelImportExport,代碼行數:101,代碼來源:EP.aspx.cs


注:本文中的OfficeOpenXml.ExcelPackage.Load方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。