Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
   
 

Registered : 102,773

HOME > บทความจากสมาชิก > อ่าน Excel (xlsx) บน .Net Application ด้วย Library ของ EPPlus (VB.Net,C#)



 

อ่าน Excel (xlsx) บน .Net Application ด้วย Library ของ EPPlus (VB.Net,C#)

อ่าน Excel (xlsx) บน .Net Application ด้วย Library ของ EPPlus (VB.Net,C#) อีกความสามารถหนึ่งของ EPPlus ที่มีประโยชน์และควรศึกษานำไปใช้งาน คือ การใช้ EPPlus อ่านข้อมูลจาก Excel ไฟล์เพื่อนำไปใช้กับ Application ที่พัฒนาด้วย .Net Application โดยวิธีการอ่านนั้น ในตัวอย่างนี้จะมีทั้งแบบการอ่านข้อมูลทีล่ะ Cell แล้วดึงค่าไปใช้ หรือว่าจะอ่านข้อมูลทั้ง Column และ Rows แล้วนำไปจัดเก็บลงใน DataTable หรือว่า List<T> ซึ่งจะสะดวกต่อการนำไปใช้งาน อาทิเชร นำไปใช้กับพวก Control ที่เป็น DataSource ต่างๆ สำหรับตัวอย่างในบทความนี้มีทั้งภาษา VB.Net และ C# และมีตัวอย่างประกอบอยู่ 2-3 ตัวอย่าง



EPPlus .Net Library for Excel Spreadsheets


ตอนที่ 1 : EPPlus สุดยอด .Net Library Spreadsheets ในการอ่าน-เขียนไฟล์ Excel (VB.Net,C#)

สำหรับความรวดเร็วในการอ่านนั้นทางผู้พัฒนาแจ้งว่าสามารถอ่านได้ถึง 50,000 Cell ต่อ 1 วินาที ซึ่งเป็นเป็นความสามารถที่สามารถอ่านได้อย่างรวดเร็ว เมื่อเปรียบเทียบกับ Library อื่นๆ ที่เคยใช้มา








ในการเรียกใช้งานให้ Import หรือ using ต่างๆ ดังนี้ System.Text, System.IO, OfficeOpenXml, System.Data


Example 1 : การอ่านไฟล์ Excel แบบง่าย ๆ

EPPlus Excel Library for .Net

ไฟล์ Excel ที่จะอ่าน

Code (VB.Net)
        Dim excel As New FileInfo(Server.MapPath("Xls/myData.xlsx"))
        Using package = New ExcelPackage(excel)
            Dim workbook = package.Workbook

            '*** Sheet 1
            Dim worksheet = workbook.Worksheets.First()

            '*** Result
            Me.lblResult1.Text = worksheet.Cells("A1").Text
            Me.lblResult2.Text = worksheet.Cells("B2").Text
            Me.lblResult3.Text = worksheet.Cells("C3").Text
        End Using

Code (C#)
            FileInfo excel = new FileInfo(Server.MapPath(@"Xls/myData.xlsx"));
            using (var package = new ExcelPackage(excel))
            {
                var workbook = package.Workbook;

                //*** Sheet 1
                var worksheet = workbook.Worksheets.First();

                //*** Result
                this.lblResult1.Text = worksheet.Cells["A1"].Text;
                this.lblResult2.Text = worksheet.Cells["B2"].Text;
                this.lblResult3.Text = worksheet.Cells["C3"].Text;
            }

Result

EPPlus Excel Library for .Net


Example 2 : การอ่าน Excel แล้วแปลงให้เป็น DataTable

EPPlus Excel Library for .Net

ตัวอย่างไฟล์ Excel ที่จะอ่านและแปลงให้เป็น DataTable

Code (VB.Net)
    Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load

        Dim excel As New FileInfo(Server.MapPath("Xls/myData.xlsx"))
        Using package = New ExcelPackage(excel)
            Dim workbook = package.Workbook

            '*** Sheet 1
            Dim worksheet = workbook.Worksheets.First()

            '*** DataTable & DataSource
            Dim dt As DataTable = ConvertToDataTable(worksheet)

            Me.myGridView.DataSource = dt
            Me.myGridView.DataBind()
        End Using

    End Sub

    Private Function ConvertToDataTable(oSheet As ExcelWorksheet) As DataTable
        Dim totalRows As Integer = oSheet.Dimension.[End].Row
        Dim totalCols As Integer = oSheet.Dimension.[End].Column
        Dim dt As New DataTable(oSheet.Name)
        Dim dr As DataRow = Nothing
        For i As Integer = 1 To totalRows
            If i > 1 Then
                dr = dt.Rows.Add()
            End If
            For j As Integer = 1 To totalCols
                If i = 1 Then
                    dt.Columns.Add(oSheet.Cells(i, j).Value.ToString())
                Else
                    dr(j - 1) = oSheet.Cells(i, j).Value.ToString()
                End If
            Next
        Next
        Return dt
    End Function

Code (C#)
       protected void Page_Load(object sender, EventArgs e)
        {

            FileInfo excel = new FileInfo(Server.MapPath(@"Xls/myData.xlsx"));
            using (var package = new ExcelPackage(excel))
            {
                var workbook = package.Workbook;

                //*** Sheet 1
                var worksheet = workbook.Worksheets.First();

                //*** DataTable & DataSource
                DataTable dt = ConvertToDataTable(worksheet);

                this.myGridView.DataSource = dt;
                this.myGridView.DataBind();
            }

        }

        private DataTable ConvertToDataTable(ExcelWorksheet oSheet)
        {
            int totalRows = oSheet.Dimension.End.Row;
            int totalCols = oSheet.Dimension.End.Column;
            DataTable dt = new DataTable(oSheet.Name);
            DataRow dr = null;
            for (int i = 1; i <= totalRows; i++)
            {
                if (i > 1) dr = dt.Rows.Add();
                for (int j = 1; j <= totalCols; j++)
                {
                    if (i == 1)
                        dt.Columns.Add(oSheet.Cells[i, j].Value.ToString());
                    else
                        dr[j - 1] = oSheet.Cells[i, j].Value.ToString();
                }
            }
            return dt;
        }

Result

EPPlus Excel Library for .Net

Example 3 : การอ่านข้อมูลจาก Excel และ Import/Insert ลงใน Database ของ SQL Server

EPPlus Excel Library for .Net

ตัวอย่างไฟล์ Excel ที่จะนำเข้า Database

EPPlus Excel Library for .Net

สร้าง Table เพื่อรองรับข้อมูลที่จะ Insert

Code (VB.Net)
        Dim excel As New FileInfo(Server.MapPath("Xls/myData.xlsx"))
        Using package = New ExcelPackage(excel)
            Dim workbook = package.Workbook

            '*** Sheet 1
            Dim worksheet = workbook.Worksheets.First()

            Dim strConnString As String = "Server=localhost;UID=sa;PASSWORD=;database=mydatabase"
            Dim objConn = New SqlConnection(strConnString)
            objConn.Open()

            '*** Loop to Insert
            Dim totalRows As Integer = worksheet.Dimension.[End].Row
            For i As Integer = 2 To totalRows
                Dim strSQL As String = "INSERT INTO myTable (Column1,Column2,Column3,Column4,Column5) " &
                    " VALUES  (" + " '" + worksheet.Cells(i, 1).Text.ToString() + "', " &
                    " '" + worksheet.Cells(i, 2).Text.ToString() + "', " &
                    " '" + worksheet.Cells(i, 3).Text.ToString() + "', " &
                    " '" + worksheet.Cells(i, 4).Text.ToString() + "', " &
                    " '" + worksheet.Cells(i, 5).Text.ToString() + "' " + ")"
                Dim objCmd = New SqlCommand(strSQL, objConn)
                objCmd.ExecuteNonQuery()
            Next

            objConn.Close()
        End Using

Code (C#)
            FileInfo excel = new FileInfo(Server.MapPath(@"Xls/myData.xlsx"));
            using (var package = new ExcelPackage(excel))
            {
                var workbook = package.Workbook;

                //*** Sheet 1
                var worksheet = workbook.Worksheets.First();

                string strConnString = @"Server=localhost;UID=sa;PASSWORD=;database=mydatabase";
                var objConn = new SqlConnection(strConnString);
                objConn.Open();

                //*** Loop to Insert
                int totalRows = worksheet.Dimension.End.Row;
                for (int i = 2; i <= totalRows; i++)
                {
                    string strSQL = "INSERT INTO myTable (Column1,Column2,Column3,Column4,Column5) "
                        + " VALUES  ("
                        + " '" + worksheet.Cells[i, 1].Text.ToString() + "', "
                        + " '" + worksheet.Cells[i, 2].Text.ToString() + "', "
                        + " '" + worksheet.Cells[i, 3].Text.ToString() + "', "
                        + " '" + worksheet.Cells[i, 4].Text.ToString() + "', "
                        + " '" + worksheet.Cells[i, 5].Text.ToString() + "' "
                        + ")";
                    var objCmd = new SqlCommand(strSQL, objConn);
                    objCmd.ExecuteNonQuery();
                }

                objConn.Close();
            }

Result

EPPlus Excel Library for .Net

ข้อมูลถุก Insert ลงใน Database ของ SQL Server

ในตัวอย่างนี้จะใช้ Database ของ SQL Server ในกรณีที่จะใช้ Database อื่น ๆ อ่านได้จากบทความนี้


บทความที่เกี่ยวข้อง
Go to : ASP.Net Excel and EPPlus Generate Excel file
Go to : ASP.Net Excel & EPPlus Cell Ranges/Border
Go to : ASP.Net Excel & EPPlus Cell styling (Color, Font, Alignments)
Go to : ASP.Net Excel & EPPlus Open Excel and Write Excel (Template)
Go to : ASP.Net Excel & EPPlus Read Excel/Cell file
Go to : ASP.Net Excel & EPPlus Convert Excel DataTable
Go to : ASP.Net Excel & EPPlus Import Excel To Database
Go to : ASP.Net Excel & EPPlus Generate Excel Report from Database


   
Share
Bookmark.   

  By : TC Admin
  Article : บทความเป็นการเขียนโดยสมาชิก หากมีปัญหาเรื่องลิขสิทธิ์ กรุณาแจ้งให้ทาง webmaster ทราบด้วยครับ
  Score Rating :
  Create Date : 2017-03-21
  Download : No files
Sponsored Links
ตอนที่ 11 : การ Debug Stored Procedure บน Visual Studio 2010,2012,2013 และอื่น ๆ
ตอนที่ 11 : การ Debug Stored Procedure บน Visual Studio 2010,2012,2013 และอื่น ๆ
ตอนที่ 11 : การ Debug Stored Procedure บน Visual Studio 2010,2012,2013 และอื่น ๆ
Rating : Update : 2015-10-10 10:51:48
C# การใช้งาน BindingSource กับ combobox แบบบ้าน บ้าน
C# การใช้งาน BindingSource กับ combobox แบบบ้าน บ้าน
C# การใช้งาน BindingSource กับ combobox แบบบ้าน บ้าน
Rating : Update : 2016-03-29 09:21:12
PHP การใช้งาน Graph API Facebook Notifications With Javascript sdk
PHP การใช้งาน Graph API Facebook Notifications With Javascript sdk
การใช้งาน Graph API Facebook ในส่วนของการ Notification หรือการแจ้งเตือน ด้วย Javascript sdk อย่างง่าย
Rating : Update : 2016-07-22 21:29:51
Oracle สอนเขียน Stored Procedure, Table, View, Function, Trigger บน Oracle Database
Oracle สอนเขียน Stored Procedure, Table, View, Function, Trigger บน Oracle Database
Oracle สอนเขียน Stored Procedure, Table, View, Function, Trigger บน Oracle Database
Rating : Update : 2016-01-26 09:11:15
List(T) คืออะไร Generic Class ของ List ใช้งานกับ Entity Framework และ LINQ to Entities
List(T) คืออะไร Generic Class ของ List ใช้งานกับ Entity Framework และ LINQ to Entities
เป็น Generic Type ของ List(T) ที่ใช้สำหรับการจัดการ Collection วัตถุมีรูปแบบเหมือนกับ Array แต่เก็บหลายมิติ ตามชนิดและ Data Type ของ Object ที่ต้องการเก็บ แต่ List เป็นมากกว่ากว่า Array คือ List สามารถ จัดการ Index
Rating : Update : 2015-12-11 22:34:17
Android Taking Photo and Save Photo to Storage (SD Card)
Android Taking Photo and Save Photo to Storage (SD Card)
ในตอนที่สองของ Camera Taking Photo จะเป็นการนำ Result ที่ได้จากการถ่ายรูปจาก Camera มาจัดเก็บเป็นไฟล์ลงใน Storage (SD Card) ซึ่งวิธีการนั้นคือแทนที่จะนำ Result ภาพที่ได้มาแสดงผลจะใช้การนำมาสร้างเป็นรูปภาพ Image
Rating : Update : 2015-11-28 07:02:07
วิธี Update โปรแกรม Windows 8.0 ให้เป็น Windows 8.1 แบบฟรี ๆ
วิธี Update โปรแกรม Windows 8.0 ให้เป็น Windows 8.1 แบบฟรี ๆ
Windows 8.1 ได้ออกมาได้ซะระยะหนึ่งแล้ว ซึ่งมีการปรับปรุงในหลาย ๆ เพิ่มเติมจาก Windows 8.0 และเราสามารถ Update ให้เป็น Windows 8.1 Pro แบบใช้งานได้ฟรี ๆ
Rating : Update : 2015-10-02 12:49:30
ThaiCreate.Com Forum

Comunity Forum Free Web Script
Jobs Freelance Free Uploads
Free Web Hosting Free Tools

สอน PHP ผ่าน Youtube ฟรี
สอน Android การเขียนโปรแกรม Android
สอน Windows Phone การเขียนโปรแกรม Windows Phone 7 และ 8
สอน iOS การเขียนโปรแกรม iPhone, iPad
สอน Java การเขียนโปรแกรม ภาษา Java
สอน Java GUI การเขียนโปรแกรม ภาษา Java GUI
สอน JSP การเขียนโปรแกรม ภาษา Java
สอน Struts การเขียนโปรแกรม Java Struts Framework
สอน jQuery การเขียนโปรแกรม ภาษา jQuery
สอน Yii  Framework การเขียนโปรแกรม ภาษา PHP กับ Yii
สอน .Net การเขียนโปรแกรม ภาษา .Net
Free Tutorial
สอน Entity Framework
สอน Android
สอน Java เขียน Java
Java GUI Swing
สอน JSP (Web App)
iOS (iPhone,iPad)
Windows Phone
Windows Azure
Windows Store
Laravel Framework
Yii PHP Framework
สอน jQuery
สอน jQuery กับ Ajax
สอน PHP OOP (Vdo)
Ajax Tutorials
SQL Tutorials
สอน SQL (Part 2)
JavaScript Tutorial
Javascript Tips
Microsoft Access
MySQL Tutorials
-- Stored Procedure
MariaDB Database
SQL Server Tutorial
SQL Server 2005
SQL Server 2008
SQL Server 2012
-- Stored Procedure
Oracle Database
-- Stored Procedure
SVN (Subversion)
แนวทางการทำ SEO
ปรับแต่งเว็บให้โหลดเร็ว

สุดยอด Source Code V2.0
 

แจ้งชำระเงิน/โอนเงิน
 

Hit Link
   


Acc : thaicreate@hotmail.com






Load balance : Server 01
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2017 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
for Contact Us : [Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 , 089-968-0655 อัตราราคา คลิกที่นี่