2

こんにちは、 を使用せずに Excel データをロードすることは可能ですかOLEDB?.xls and .xlsx

ConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + pFilePath + ";Extended Properties=\"Excel 8.0;HDR=Yes;IMEX=2\"";

ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + pFilePath + ";Extended Properties=\"Excel 12.0;HDR=Yes;IMEX=2\"";

私のシステムでは12.0関連dllが存在しないため、エラーが発生しました。したがって、一般的なアプローチではなく、私の要件を達成する方法があるかどうかを知りたいです

書かれたサンプルコード

public void Method(string pFilePath)
    {
        DataTable dt = new DataTable();

        using (SpreadsheetDocument spreadSheetDocument = SpreadsheetDocument.Open(pFilePath, false))
        {

            WorkbookPart workbookPart = spreadSheetDocument.WorkbookPart;
            IEnumerable<Sheet> sheets = spreadSheetDocument.WorkbookPart.Workbook.GetFirstChild<Sheets>().Elements<Sheet>();
            string relationshipId = sheets.First().Id.Value;
            WorksheetPart worksheetPart = (WorksheetPart)spreadSheetDocument.WorkbookPart.GetPartById(relationshipId);
            Worksheet workSheet = worksheetPart.Worksheet;
            SheetData sheetData = workSheet.GetFirstChild<SheetData>();
            IEnumerable<Row> rows = sheetData.Descendants<Row>();

            foreach (Cell cell in rows.ElementAt(0))
            {
                dt.Columns.Add(GetCellValue(spreadSheetDocument, cell));
            }

            foreach (Row row in rows)
            {
                DataRow tempRow = dt.NewRow();

                for (int i = 0; i < row.Descendants<Cell>().Count(); i++)
                {
                    tempRow[i] = GetCellValue(spreadSheetDocument, row.Descendants<Cell>().ElementAt(i - 1));
                }

                dt.Rows.Add(tempRow);
            }

        }
        dt.Rows.RemoveAt(0);
    }
    public static string GetCellValue(SpreadsheetDocument document, Cell cell)
    {
        SharedStringTablePart stringTablePart = document.WorkbookPart.SharedStringTablePart;
        string value = cell.CellValue.InnerXml;

        if (cell.DataType != null && cell.DataType.Value == CellValues.SharedString)
        {
            return stringTablePart.SharedStringTable.ChildElements[Int32.Parse(value)].InnerText;
        }
        else
        {
            return value;
        }
    }

しかし、foreach (Row row in rows)この状態では例外が発生していますSpecified argument was out of the range of valid values. Parameter name: index

4

4 に答える 4

5

Excel から mysql データベースに読み込みました。たぶん、それを行う最も良い方法ではありません。しかし、ここに私のコードがあります:

 Excel.Application xlApp = new Excel.Application();

        Excel.Workbook xlWorkbook = xlApp.Workbooks.Open(@"\\xxxx\yyyy.xlsx");
        Excel._Worksheet xlWorksheet = xlWorkbook.Sheets[1];
        Excel.Range xlRange = xlWorksheet.UsedRange;

        int rowCount = xlRange.Rows.Count;
        int colCount = xlRange.Columns.Count;
        string Kund = "";



        for (int i = 1; i <= rowCount; i++)
        {
            for (int j = 1; j <= colCount; j++)
            {


                if ((j == 1) && (i > 1))
                {
                    MySqlConnection conn = new MySqlConnection(databas);

                    Kund = xlRange.Cells[i, j].Value2.ToString();
                }
                ...
            }
                ...
         }
           xlApp.Workbooks.Close();

使用する必要がありますusing Excel = Microsoft.Office.Interop.Excel;

于 2013-06-11T10:48:41.167 に答える
0

私は 1 か月前に Excel シートからかなり重いデータを読み取っていましたが、Excel から読み取るための優れたオープン ソース プロジェクトである codeplex の ExcellReader を使用しました。それがあなたにも役立つことを願っています。それをチェックしてください..

于 2013-06-11T10:47:36.820 に答える
-1

そのために使用できる多くのサードパーティ コンポーネントがあります。NuGet で非常に大きなリストを見つけてください。

https://nuget.org/packages?q=excel

Office をインストールする必要がないものもあります (「スタンドアロン」というキーワードに注意してください)。

すべてが無料であるとは限らないため、適切なソフトウェア選択プロセスを実行して、要件に合ったものを確認する必要があります.

于 2013-06-11T10:37:04.560 に答える
-1

XLSファイルを読むための非常に多くの提案がスタックで議論されています

C# で Excel 2003 & 2007 を読む

この希望を確認してください。

于 2013-06-12T06:49:49.937 に答える