Feedback

C# - Spaltennamen eines Arbeitsblatts einer Excel-Datei auslesen

Veröffentlicht von am 21.09.2007
(1 Bewertungen)
Schneller als über Interop lassen sich Informationen über eine Exceldatei über OleDb auslesen. Benötigt wird die Methode GetOleDbSchemaTable des OleDbConnection-Objekts.

Über die Klasse OleDbSchemaGuid und den entsprechenden Einschränkungen wird angegeben, welche Informationen man haben möchte.
GFU-Schulungen  [Anzeige]

C# 2017/2015/2013 Grundlagen

Nach Abschluss des Kurses sind Ihnen die Datentypen und Klassenbibliotheken von C# bekannt. Außerdem sind Sie in der Lage, mit Variablen umzugehen und deren Typen zu konvertieren. Sie definieren Namespaces und setzen diese ein, Sie erstellen eigene Klassen  und bauen Trouble Shooting ein.

ASP.NET Core und Angular Komplett für .NET-Entwickler

Sie  lernen in drei (3) Tagen wie man mit  ASP.NET Core und den Technologien  MVC, Entity Framework, WebAPI und  Razor professionelle sowie moderne  Web-Anwendungsarchitekturen aufbaut.  Die Schulung ist der perfekte  Einstieg um insbesondere datengetriebene  und präsentationsorientierte  Applikationen auf Basis der robusten und  skalierbaren ASP.NET Core  Plattform zu erstellen. Nach der Veranstaltung kennen Sie die Konzepte von Angular und können Angular in neue und bestehende ASP.NET-Anwendungen einsetzen.

private string[] GetColumnNames(string excelFile, string worksheetName)
{
	// Namen der Excel-Arbeitsblätter enden immer mit $ ("Tabelle1$")
	if (!worksheetName.EndsWith("$"))
	{
		worksheetName = worksheetName + "$";
	}

	OleDbConnection con = new OleDbConnection();
	con.ConnectionString = "Data Source=" + excelFile + 
		";Provider=Microsoft.Jet.OLEDB.4.0" +
		";Extended Properties=Excel 8.0";
	
	con.Open();
	
	DataTable tab = con.GetOleDbSchemaTable(
		OleDbSchemaGuid.Columns, 
		new object[] {null, null, worksheetName, null});
	
	con.Close();

	string[] columnNames = new string[tab.Rows.Count];

	for (int i = 0; i < tab.Rows.Count; i++)
	{
		columnNames[i] = tab.Rows[i]["Column_Name"].ToString();
	}

	return columnNames;
}
Abgelegt unter Excel, OleDb.

Kommentare zum Snippet

 

Logge dich ein, um hier zu kommentieren!