Windows Azure Cloud Storage ermöglicht es Ihnen bereits ab 0,10€ pro GB/Monat die Vorteile der Cloud zu nutzen.
Willkommen bei dotnet-snippets.de! Snippet hinzufügen Login Registrieren
Snippets in der Datenbank: 1551 | Anzahl registrierter User: 1841 | Besucher online: 161
Hauptmenü
Home
Top Ten
Zufälliger Snippet
FAQs
.NET Community
dotnet-forum.de
dotnet-kicks.de
Social

RSS Feeds
Rss Alle Snippets
Rss C#
Rss VB.NET
Rss C++
Rss ASP.NET
Partner
Member of Microsoft Community Leader/Insider Program (CLIP)

Excel: alle Tabellen über OleDb in DataSet lesen


Autor: Bauer Michael
Sprache: C#
Bewertung:
7.59 (4 votes)
Anzahl der Aufrufe: 24905
  
Kick it on dotnet-kicks.de  

Beschreibung:

Hier wird gezeigt, wie sämtliche Daten aus einer Excel-Datei über OleDb in ein DataSet eingelesen werden können.

Getestet mit VS 2003 u. Excel 2003


Abgelegt unter: Excel, OleDb.



C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
/// <summary>
/// Holt die Daten aus einer Excel-Datei in ein DataSet
/// </summary>
/// <param name="excelFile">Pfad zur Excel-Datei</param>
/// <param name="headers">Haben die Tabellenspalten Überschriften</param>
/// <returns>DataSet</returns>
private DataSet GetExcelDataSet(string excelFile, bool headers)
{
	DataSet ds = new DataSet();

	OleDbConnection con = new OleDbConnection();
	con.ConnectionString = "Data Source=" + excelFile + 
		";Provider=Microsoft.Jet.OLEDB.4.0;";
	
	if (headers)
		con.ConnectionString += @"Extended Properties=""Excel 8.0;HDR=Yes""";
	else
		con.ConnectionString += @"Extended Properties=""Excel 8.0;HDR=No""";
	
	con.Open();
	DataTable sheets = con.GetOleDbSchemaTable(
		OleDbSchemaGuid.Tables, 
		new object[] {null, null, null, "TABLE"});

	foreach (DataRow sheet in sheets.Rows)
	{
		string tableName = sheet["Table_Name"].ToString();
		string sql = "SELECT * FROM [" + tableName + "]";
		OleDbDataAdapter adap = new OleDbDataAdapter(sql, con);
		adap.Fill(ds, tableName);
	}
	
	con.Close();
	return ds;
}
Sie haben Fragen zu diesem Snippet oder brauchen Hilfe bei der .NET Entwicklung?
Freundliche und kompetente Entwickler helfen Ihnen gern weiter im Forum für .NET Entwicklung.



Kommentare:
(Zum Schreiben von Kommentaren bitte anmelden.)

Kaffeeholiker schrieb am:  06.05.2011 13:59:23

Super Sache dieses OleDB.
Falls ich einen Feheler bekommen solltet, dass ein Treiber nicht geladen werden kann setzt einfach die Properties in Anführungszeichen. Dann läufts.


schlecht sehr gut
1 2 3 4 5 6 7 8 9 10
Nur angemeldete User können Snippets bewerten.