gpt4 book ai didi

c# - 不使用OLEDB从excel导入数据

转载 作者:行者123 更新时间:2023-12-04 04:54:01 24 4
gpt4 key购买 nike

大家好,是否可以在不使用 OLEDB 的情况下加载 excel 数据, 我已经使用连接字符串为 .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)这种情况我得到一个异常(exception) Specified argument was out of the range of valid values.
Parameter name: index

最佳答案

我从 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;

关于c# - 不使用OLEDB从excel导入数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17041954/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com