首頁 >後端開發 >C++ >如何使用 C# 從 Excel 檔案讀取資料?

如何使用 C# 從 Excel 檔案讀取資料?

Mary-Kate Olsen
Mary-Kate Olsen原創
2025-01-11 16:26:45855瀏覽

How to Read Data from an Excel File Using C#?

使用C#讀取Excel檔案資料

問題:

如何使用C#讀取Excel檔案資料?我已經嘗試打開文件並將其複製到剪貼簿,但不確定如何繼續操作。

解答:

使用C#讀取Excel檔案數據,您可以考慮以下方法:

1. 建立Excel物件:

<code class="language-csharp">Excel.ApplicationClass ExcelObj = new Excel.ApplicationClass();
ExcelObj.Visible = false;</code>

2. 開啟工作簿與工作表:

<code class="language-csharp">Excel.Workbook theWorkbook = ExcelObj.Workbooks.Open(s.Text, 0, true, 5, "", "", true, Excel.XlPlatform.xlWindows, "\t", false, false, 0, true, false, false);
Excel.Worksheet worksheet = (Excel.Worksheet)theWorkbook.Worksheets.get_Item(count);</code>

3. 將儲存格存取為命名範圍:

<code class="language-csharp">Excel.Range range = sheet.get_Range("A1", Missing.Value);</code>

4. 取得儲存格值:

<code class="language-csharp">range.Text // 返回用户可见文本
range.Value2 // 返回Excel中存储的实际值</code>

5. 迭代單元格:

<code class="language-csharp">Excel.Range range1 = sheet.get_Range("A1:A5", Missing.Value);
if (range1 != null)
{
    foreach (Excel.Range r in range1)
    {
        string user = r.Text;
        string value = r.Value2;
    }
}</code>

清理:

請記住以與創建相反的順序關閉並釋放Excel對象,以便正確處置它們。

範例:

<code class="language-csharp">using System;
using ExcelTools = Ms.Office;
using Excel = Microsoft.Office.Interop.Excel;

public class ExcelReader
{
    public static void ReadWorkbook(string fileName)
    {
        Excel.Application excel = null;
        Excel.Workbook wkb = null;

        try
        {
            excel = new Excel.Application();
            wkb = ExcelTools.OfficeUtil.OpenBook(excel, fileName);

            Excel.Worksheet sheet = wkb.Sheets["Data"] as Excel.Worksheet;
            Excel.Range range = sheet.get_Range("A1", Missing.Value);

            string A1 = String.Empty;
            if (range != null)
                A1 = range.Text.ToString();

            Console.WriteLine("A1单元格的值: {0}", A1);
        }
        catch (Exception ex)
        {
            // 在此处处理错误
        }
        finally
        {
            ExcelTools.OfficeUtil.ReleaseRCM(wkb);
            ExcelTools.OfficeUtil.ReleaseRCM(excel);
        }
    }
}</code>

附加說明:

  • 將可見性設為false以防止顯示Excel。
  • 考慮使用OleDb提供者作為存取Excel資料的替代方法。
  • 要找特定值,請使用Excel.Cells.Find。

以上是如何使用 C# 從 Excel 檔案讀取資料?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn