vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
sevDataGrid - Gönnen Sie Ihrem SQL-Kommando diesen krönenden Abschluß!  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2024
 
zurück

 Sie sind aktuell nicht angemeldet.Funktionen: Einloggen  |  Neu registrieren  |  Suchen

C# Ecke
C# mit Excel 
Autor: Grauer Wolf
Datum: 30.06.15 14:32

Hallo, ich möchte gerne 3 .csv-Dateien in ein Excel.Workbook eintragen und zwar so, das jede der 3 Dateien ein einzelnes Worksheet belegt. Leider macht Excel jedes Mal ein neues Workbook auf. Kann mir bitte jemand mit einer Idee helfen? Ich kann neue Worksheets erzeugen, auch darauf zugreifen, Zellen beschreiben, aber bekomme die 3 Dateien nicht einzeln in die Worksheets. Danke und Gruß

WME

Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: C# mit Excel 
Autor: Blackbox
Datum: 30.06.15 19:55

Hi,

das liegt daran, dass Du Workbook.Open aufrufst anstatt die Tabellen eines Workbook.
Näheres, wenn Du ein bißchen Code beibringst.
Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: C# mit Excel 
Autor: Grauer Wolf
Datum: 30.06.15 20:46

Hallo,
danke erstmal für die Antwort.

Hier etwas Code...

using Excel = Microsoft.Office.Interop.Excel;
.
.
.
//Excel öffnen und Arbeitsblätter erzeugen
Excel.Application myExcelApplication;
Excel.Workbook myExcelWorkbook;
Excel.Worksheet myExcelWorkSheet;
myExcelApplication = null;

//Excel Prozess initialisieren
myExcelApplication = new Excel.Application();
myExcelApplication.Visible = true;
myExcelApplication.ScreenUpdating = true;


//hier öffne ich das Workbook mit der ersten .csv-Datei
myExcelApplication.Workbooks.Open(datei, ReadOnly: false);

//und füge 2 leere Worksheets dazu
myExcelWorkSheet = (Excel.Worksheet)myExcelApplication.Worksheets.Add();
myExcelWorkSheet = (Excel.Worksheet)myExcelApplication.Worksheets.Add();

//hier die 3 Arbeitsblätter umbenennen
((Excel.Worksheet)myExcelWorkbook.Sheets["Sheet1"]).Select();
((Excel.Worksheet)myExcelWorkbook.Sheets["Sheet1"]).Name = "RSD's";
((Excel.Worksheet)myExcelWorkbook.Sheets["Sheet2"]).Select();
((Excel.Worksheet)myExcelWorkbook.Sheets["Sheet2"]).Name = "Konzentrationen";
((Excel.Worksheet)myExcelWorkbook.Sheets["Sheet3"]).Select();
((Excel.Worksheet)myExcelWorkbook.Sheets["Sheet3"]).Name = "Original";


Gruß
Wolfgang

WME

Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: C# mit Excel 
Autor: Grauer Wolf
Datum: 06.07.15 20:06

Hm schade, keine Antwort mehr

WME

Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: C# mit Excel 
Autor: Grauer Wolf
Datum: 10.07.15 18:12

Hallo,
habe jetzt mittels eines Excel-Macros das Einlesen realisiert und bekomme folgenden Code:

.
.
.
With ActiveSheet.QueryTables.Add(Connection:= _
"TEXT;C:\Agilent_Online\Online_Uni\Test_WME_Ori.csv", Destination:=Range( _
"$A$1"))
.CommandType = 0
.Name = "Test_WME_Ori"
.FieldNames = True
.RowNumbers = False
.FillAdjacentFormulas = False
.
.
.

Leider schaffe ich es nicht, die With-Anweisung nach C# zu übertragen. Kann da mal bitte jemand helfen???

Gruß
Wolfgang

WME

Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: C# mit Excel 
Autor: ModeratorDaveS (Moderator)
Datum: 10.07.15 18:45

im Prinzip sowas

QueryTable qt = myExcelApp.ActiveSheet.QueryTables.Add(....);
qt.CommandType = 0;

usw.

________
Alle Angaben ohne Gewähr. Keine Haftung für Vorschläge, Tipps oder sonstige Hilfe, falls es schiefgeht, nur Zeit verschwendet oder man sonst nicht zufrieden ist

Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: C# mit Excel 
Autor: Grauer Wolf
Datum: 13.07.15 21:46

Hallo,

danke für die Hilfe und Denkanstöße. Habs jetzt, so funktioniert's:

Excel.Worksheet activeSheet = null;
Excel.QueryTables queryTables = null;
Excel.QueryTable queryTable = null;
Excel.Range insertRange = null;

activeSheet = myExcelApplication.ActiveSheet;
insertRange = activeSheet.Range["$A$1"];
queryTables = activeSheet.QueryTables;
queryTable = queryTables.Add("TEXT;" + anzresults[z], insertRange);
queryTable.AdjustColumnWidth = true;
queryTable.TextFileParseType = Excel.XlTextParsingType.xlDelimited;
queryTable.TextFileTextQualifier = Excel.XlTextQualifier.xlTextQualifierDoubleQuote;
queryTable.TextFileCommaDelimiter = true;
queryTable.Refresh();

Gruß
WOlfgang

WME

Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Sie sind nicht angemeldet!
Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.

Einloggen  |  Neu registrieren

Funktionen:  Zum Thema  |  GesamtübersichtSuchen 

nach obenzurück
 
   

Copyright ©2000-2024 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel