AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Sonstige Fragen zu Delphi Delphi StringGrid mit Spalten nach Excel exportieren
Thema durchsuchen
Ansicht
Themen-Optionen

StringGrid mit Spalten nach Excel exportieren

Offene Frage von "L85"
Ein Thema von L85 · begonnen am 14. Mai 2006 · letzter Beitrag vom 19. Sep 2008
Antwort Antwort
Seite 2 von 2     12   
ErdNussLocke

Registriert seit: 30. Jan 2006
104 Beiträge
 
#11

Re: StringGrid mit Spalten nach Excel exportieren

  Alt 18. Sep 2008, 12:33
hmm schaffs net

Also die Variable ist hinzugefügt

An welche Stelle muss denn

Delphi-Quellcode:
SelRange := XLApp.Workbooks[M].Worksheets[N].Range[RefToCell(1, 1), RefToCell(SheetRowCount, SheetColCount)];
SelRange.Select;
XLApp.Selection.NumberFormat := '@';
genau hin?

Würde es an die NumberFormat Stelle schreiben:

Delphi-Quellcode:
//Sheets befüllen
    for M := 1 to BookCount do
    begin
        for N := 1 to SheetCount do
        begin
          //Daten aus Grid holen
          Data := VarArrayCreate([1, Grid.RowCount, 1, SheetColCount], varVariant);
          for I := 0 to SheetColCount - 1 do
            for J := 0 to SheetRowCount - 1 do
              if ((I+256*(N-1)) <= Grid.ColCount) and ((J+65536*(M-1)) <= Grid.RowCount) then
                Data[J + 1, I + 1] := Grid.Cells[I+256*(N-1), J+65536*(M-1)];

          XLApp.Worksheets[N].Select;
          XLApp.Workbooks[M].Worksheets[N].Name := SheetName + IntToStr(N);
          //Zellen als String Formatieren
 //Diese dann weg? //XLApp.Workbooks[M].Worksheets[N].Range[RefToCell(1, 1), RefToCell(SheetRowCount,
                           //SheetColCount)].Select;
          SelRange := XLApp.Workbooks[M].Worksheets[N].Range[RefToCell(1, 1), RefToCell(SheetRowCount, SheetColCount)];
          SelRange.Select;
          XLApp.Selection.NumberFormat := '@';
          XLApp.Workbooks[M].Cells.EntireColumn.AutoFit;
          XLApp.Workbooks[M].Worksheets[N].Range['A1'].Select;
          //Daten dem Excelsheet übergeben
          Sheet := XLApp.Workbooks[M].WorkSheets[N];
          Sheet.Range[RefToCell(1, 1), RefToCell(SheetRowCount,SheetColCount)].Value := Data;
        end;
    end;
und das Autofit dann hinter das Befüllen?

Delphi-Quellcode:
//...
          XLApp.Selection.NumberFormat := '@';
          XLApp.Workbooks[M].Cells.EntireColumn.AutoFit;
          XLApp.Workbooks[M].Worksheets[N].Range['A1'].Select;
          //Daten dem Excelsheet übergeben
          Sheet := XLApp.Workbooks[M].WorkSheets[N];
          Sheet.Range[RefToCell(1, 1), RefToCell(SheetRowCount,SheetColCount)].Value := Data;
        end;
    end;
   SelRange.Select;
   XLApp.Selection.Columns.AutoFit;
So hab ich es versucht, ohne Erfolg Wäre super wenn das noch recht gerückt wird

Danke sehr
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#12

Re: StringGrid mit Spalten nach Excel exportieren

  Alt 18. Sep 2008, 12:48
Hallo,

muss das Numberformat nicht mit hierhin?

Delphi-Quellcode:
XLApp.Workbooks[M].Cells.Select;
XLApp.Workbooks[M].Cells.EntireColumn.AutoFit;
XLApp.Workbooks[M].Cells.Numberformat := '@';
XLApp.Workbooks[M].Range['A1','A1'].Select;
und das ganze direkt vorm Speichern?

Stephan
  Mit Zitat antworten Zitat
ErdNussLocke

Registriert seit: 30. Jan 2006
104 Beiträge
 
#13

Re: StringGrid mit Spalten nach Excel exportieren

  Alt 18. Sep 2008, 14:44
Geht auch nicht (Wenn ich es richtig gemacht hab)

Delphi-Quellcode:
          XLApp.Workbooks[M].Worksheets[N].Range['A1'].Select;
          //Daten dem Excelsheet übergeben
          Sheet := XLApp.Workbooks[M].WorkSheets[N];
          Sheet.Range[RefToCell(1, 1), RefToCell(SheetRowCount,SheetColCount)].Value := Data;
        end;
    end;

    XLApp.Workbooks[M].Cells.Select;
    XLApp.Workbooks[M].Cells.EntireColumn.AutoFit;
    XLApp.Workbooks[M].Cells.Numberformat := '@';
    XLApp.Workbooks[M].Range['A1','A1'].Select;

    //Save Excel Worksheet
    try
      for M := 1 to BookCount do
      begin
          SaveFileName :=Copy(FileName,1,Pos('.',FileName)-1) +
          Copy(FileName,Pos('.',FileName),
          Length(FileName)-Pos('.',FileName)+1);
          if fileexists(pfadE+Form1.EExportname.text+'.xls')=true
           then deletefile(pfadE+Form1.EExportname.text+'.xls');
          XLApp.Workbooks[M].SaveAs(SaveFileName);
      end;
  Mit Zitat antworten Zitat
Benutzerbild von toms
toms
(CodeLib-Manager)

Registriert seit: 10. Jun 2002
4.648 Beiträge
 
Delphi XE Professional
 
#14

Re: StringGrid mit Spalten nach Excel exportieren

  Alt 18. Sep 2008, 16:59
Zitat von ErdNussLocke:
hmm schaffs net

Also die Variable ist hinzugefügt

An welche Stelle muss denn

Delphi-Quellcode:
SelRange := XLApp.Workbooks[M].Worksheets[N].Range[RefToCell(1, 1), RefToCell(SheetRowCount, SheetColCount)];
SelRange.Select;
XLApp.Selection.NumberFormat := '@';
genau hin?
Das Autofit muss schon statt finden, nachdem die Zellen befüllt wurden.



Delphi-Quellcode:
   XLApp.Worksheets[N].Select;
          XLApp.Workbooks[M].Worksheets[N].Name := SheetName + IntToStr(N);
          //Zellen als String Formatieren

          SelRange := XLApp.Workbooks[M].Worksheets[N].Range[RefToCell(1, 1), RefToCell(SheetRowCount, SheetColCount)];
          SelRange.Select;
 
          XLApp.Selection.NumberFormat := '@';

          XLApp.Workbooks[M].Worksheets[N].Range['A1'].Select;
          //Daten dem Excelsheet übergeben
          Sheet := XLApp.Workbooks[M].WorkSheets[N];
          Sheet.Range[RefToCell(1, 1), RefToCell(SheetRowCount,SheetColCount)].Value := Data;
     
      SelRange.Select;
          XLApp.Selection.Columns.AutoFit;
Thomas
  Mit Zitat antworten Zitat
ErdNussLocke

Registriert seit: 30. Jan 2006
104 Beiträge
 
#15

Re: StringGrid mit Spalten nach Excel exportieren

  Alt 19. Sep 2008, 11:19
Perfekt Danke euch allen!!
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 23:03 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz