AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Excel-Sheet mit Delphi verändern

Ein Thema von PPaB · begonnen am 8. Jan 2010 · letzter Beitrag vom 11. Jan 2010
Antwort Antwort
Seite 1 von 2  1 2      
PPaB

Registriert seit: 23. Jan 2009
35 Beiträge
 
#1

Excel-Sheet mit Delphi verändern

  Alt 8. Jan 2010, 20:52
Ich habe schon viel probiert, aber ich schaff es einfach nicht in Excel etwas zu verändern (Fett schreiben, Färben, Zellen fixieren...). Ich kann zwar in ein Excel-Dokument etwas eintragen, aber das andere klappt einfach nicht.
Hat da jemand eine Idee?

MfG
PPaB
  Mit Zitat antworten Zitat
dominikkv

Registriert seit: 30. Sep 2006
Ort: Gundelfingen
1.109 Beiträge
 
Delphi 2007 Professional
 
#2

Re: Excel-Sheet mit Delphi verändern

  Alt 8. Jan 2010, 20:57
Zeige uns doch, wie dus versuchst, und was dann nicht klappt.

Ansonsten kann ich dir nur dieses Tutorial geben: http://www.delphi-treff.de/tutorials...von-ms-office/
Dominik
Wer anderen eine Grube gräbt, hat ein Gruben-Grab-Gerät!
  Mit Zitat antworten Zitat
PPaB

Registriert seit: 23. Jan 2009
35 Beiträge
 
#3

Re: Excel-Sheet mit Delphi verändern

  Alt 8. Jan 2010, 21:16
habs jetzt soweit:
Delphi-Quellcode:
procedure TLieder.Excel1Click(Sender: TObject);
var Excel: Variant;
    I, J, K, L, M, N, P: integer;
    Speicherort: String;
begin
M := 13;
FindAllFiles(ExtractFilePath(Application.Exename)+'Gottesdienste/', '*.*',False);

if Excelspeichern.Execute then begin
    try
      excel := CreateOleObject('Excel.Application');
      excel.visible := False;
    except
      ShowMessage('Excel konnte nicht gestartet werden !');
    end;
    Excel.Workbooks.Add;
    for J:=0 to 11
      do begin
      Excel.Cells[1,J+1].Value :=StringGrid3.Cells[J,0];
        for I := 1 to StringGrid3.RowCount-1
        do Excel.Cells[I+2,J+1].Value :=StringGrid3.Cells[J,I];
      end;
        For N := 0 to Listbox3.Count-1 do
        begin
        Listbox2.Items.LoadFromFile(ExtractFilePath(Application.Exename)+'Gottesdienste/'+ Listbox3.Items[N]);
        M := M+1;
        Excel.Cells[1,M].Value := Copy(Listbox3.Items[N],1,Length(Listbox3.Items[N])-4);
        For P := 1 to SGBesucher.RowCount -1 do
          If SGBesucher.Cells[0,P] = Copy(Listbox3.Items[N],1,Length(Listbox3.Items[N])-4) then
              Excel.Cells[2,M].Value := SGBesucher.Cells[4,P];

        for K := 0 to Listbox2.Count - 1 do
        begin
          for L := 1 to StringGrid3.RowCount - 1 do
          begin
            If StringGrid3.Cells[0,L] = Listbox2.Items[K] then
              Excel.Cells[L+2,M].Value := 'x';
          end;
        end;
        end;
    Speicherort := Excelspeichern.FileName;
    Excel.ActiveWorkbook.SaveAs(Speicherort);
    Excel.Quit;
    Excel := Unassigned;
end;
end;
Hab aber keinen Ansatz, wie ich die erste Zeile immer in Fett umändern kann und die ganzen "x" sollten eine andere Farbe (Rot) haben.
  Mit Zitat antworten Zitat
Benutzerbild von sx2008
sx2008

Registriert seit: 15. Feb 2008
Ort: Baden-Württemberg
2.332 Beiträge
 
Delphi 2007 Professional
 
#4

Re: Excel-Sheet mit Delphi verändern

  Alt 8. Jan 2010, 21:46
Delphi-Quellcode:
Excel.Cells[1,1].Font.Color := RGB(clRed); // Zellentext rot färben
// oder auch
Excel.Cells[1,1].Interior.ColorIndex := 3; // Zelle rot färben
//
Excel.Cells[1,1].Font.Bold := True; // Schrift fett
mehr zu Excel-Objekten
fork me on Github
  Mit Zitat antworten Zitat
PPaB

Registriert seit: 23. Jan 2009
35 Beiträge
 
#5

Re: Excel-Sheet mit Delphi verändern

  Alt 8. Jan 2010, 21:51
Oh cool, danke

Noch eine Idee, wie man Zellen fixieren kann?
  Mit Zitat antworten Zitat
Benutzerbild von Chemiker
Chemiker

Registriert seit: 14. Aug 2005
1.858 Beiträge
 
Delphi 11 Alexandria
 
#6

Re: Excel-Sheet mit Delphi verändern

  Alt 8. Jan 2010, 21:59
Hallo PPaB,

zeichne Dir in Excel einen Macro auf, dann kann man Erkennen welche Befehle erforderlich sind um die Zellen zu fixieren.

Bis bald Chemiker
wer gesund ist hat 1000 wünsche wer krank ist nur einen.
  Mit Zitat antworten Zitat
PPaB

Registriert seit: 23. Jan 2009
35 Beiträge
 
#7

Re: Excel-Sheet mit Delphi verändern

  Alt 9. Jan 2010, 12:13
@Chemiker: Wie kann ich das machen? Weiß nicht, wie ich Makros aufzeichnen kann?

MSDN ist ja ganz schön, finde dort aber nicht, wie ich die Schriftgröße verändern kann.
Kann mir da vielleicht noch jemand helfen?

Edit: Ah und ich müsste noch auf dem gesamten Sheet die optimale Breite ermitteln. Geht das auch mit den Makros oder einfacher?


So danke an alle, habs jetzt rausbekommen mit den Makros.

http://www.delphipraxis.net/internal...t.php?p=296956

Hier wirds auch ganz gut erklärt.

Eine Frage hab ich noch. Wie kann ich erst in Delphi während dem laufen des Programms die Zellen zum markieren bestimmen.
Excel.Range['M3:AC' + IntToStr(I)].Select; So kann ich zwar die Zahl selbst bestimmen, aber ich möchte auch statt dem 'AC' eine Variable eingeben.
Da ich diese aber nur als Zahl habe, wollte ich fragen, wie man dies ändern kann, sodass ich diese Zellen alle markieren kann?
  Mit Zitat antworten Zitat
PPaB

Registriert seit: 23. Jan 2009
35 Beiträge
 
#8

Re: Excel-Sheet mit Delphi verändern

  Alt 10. Jan 2010, 17:22
Jedemand eine Idee, wie ich das anstellen könnte?
  Mit Zitat antworten Zitat
anubis2k5

Registriert seit: 5. Jul 2008
13 Beiträge
 
#9

Re: Excel-Sheet mit Delphi verändern

  Alt 11. Jan 2010, 04:40
Hallo PPaB!

So ganz verstehe ich deine letzte Frage nicht... Du kannst doch auch die Spalten über Variabeln ansprechen:

Delphi-Quellcode:
...
var tmpStr: String;
...
tmpStr := 'AA'; {kann an einer anderen Stelle im Code liegen}

Excel.Range['M3:tmpStr' + IntToStr(I)].Select;
Oder versuch doch noch einmal die Frage anders zu stellen
  Mit Zitat antworten Zitat
Benutzerbild von Andidreas
Andidreas

Registriert seit: 27. Okt 2005
1.110 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#10

Re: Excel-Sheet mit Delphi verändern

  Alt 11. Jan 2010, 09:02
wenn ich das richtig verstehe, dann hast hast du den spaltenwert (z.B. 'AC') als integer wert...
wennd em so ist würde ich vorschlagen das du das alphabet in einem array hinterlegst...
denn array kannst du dann so oft durch lesen bis du den gleichen wert wie in deinem integer wert hast...
davor solltest du aber deinen wert durch 26 teilen wegen den spalten mit 2 buchstaben
Ein Programmierer Programmiert durchschnittlich 15 Code Zeilen pro Tag
Wir sind hier doch nicht bei SAP!!!

Aber wir habens bald
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 22:49 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz