AGB  ·  Datenschutz  ·  Impressum  







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

Excel Diagramm einfärben

Ein Thema von ueei.net · begonnen am 15. Feb 2005 · letzter Beitrag vom 16. Feb 2005
Antwort Antwort
ueei.net

Registriert seit: 4. Mär 2004
Ort: Wels
53 Beiträge
 
#1

Excel Diagramm einfärben

  Alt 15. Feb 2005, 14:34
Hallo, folgendes Problem,

ich öffne mir mit folgendem Script eine Excel Datei:

Delphi-Quellcode:
try
    Excel := CreateOleObject('Excel.Application');
  except
    // Fehler aufgetreten
    ShowMessage ( 'Excel konnte nicht gestartet werden !' );
    Exit;
  end;
  // Dokument öffnen
  Excel.Visible := False;
  Excel.Workbooks.Open(FileName := 'hansi.xls');
Und bearbeite darin haufenweise Werte:

Delphi-Quellcode:
 Excel.Cells [zeile,2].Value := q_meinesPROZENT.AsString;
  Excel.Cells [zeile,3].Value := q_meinesGESAMT.AsString;
  .....
  .....
  .....
In der Datei befundet sich auch ein Diagramm, von dem ich abhängig von meinen Daten eine Spalte einfärben möchte. Die Position der Spalte kenne ich.

Nun hab ich mir ein Macro aufgezeichnet, welches eine Säule einfärbt, in diesem Fall die zweite. Diesen Code möchte ich in Delphi "ausführen", bzw. portieren, da im Excel keine Macros sein dürfen.

Delphi-Quellcode:
ActiveSheet.ChartObjects("Diagramm 2").Activate
    ActiveChart.SeriesCollection(1).Select
    ActiveChart.SeriesCollection(1).Points(2).Select
    With Selection.Interior
        .ColorIndex = 4
        .Pattern = xlSolid
    End With
Leider habe ich das noch nicht in Delphi umwandeln können, bin schon am verzweifeln.

Hoffe es kann mir jemand helfen. Danke.
  Mit Zitat antworten Zitat
Benutzerbild von Boombuler
Boombuler

Registriert seit: 14. Mär 2003
Ort: Osnabrück
244 Beiträge
 
Delphi 2009 Professional
 
#2

Re: Excel Diagramm einfärben

  Alt 16. Feb 2005, 08:28
Hi

Delphi-Quellcode:
Excel.ActiveSheet.ChartObjects['Diagramm 2'].Activate;
Excel.ActiveChart.SeriesCollection(1).Select; // Hier evtl () in [] umwandeln
Excel.ActiveChart.SeriesCollection(1).Points(2).Select;// Hier evtl () in [] umwandeln
Excel.Selection.Interior.ColorIndex := 4
Excel.Selection.Interior.Pattern := xlSolid
Greetz
Boombuler
"Look at you, Hacker. A pathetic creature of meat and bone, panting and sweating as you run through my corridors. How can you challenge a perfect, immortal machine?"
SwapIt Highscore:
  Mit Zitat antworten Zitat
ueei.net

Registriert seit: 4. Mär 2004
Ort: Wels
53 Beiträge
 
#3

Re: Excel Diagramm einfärben

  Alt 16. Feb 2005, 13:47
Hallo,

das Funktioniert schon mal so ganz gut (einige kleine Änderungen).

Gibt jetzt nur ein Problem. Wenn das Digramm ausgewählt ist, kann keine Zelle mehr beschrieben werden, dann kommt immer ein OLE Fehler.

Habe versucht analog zum Macro den Code einzusetzen:

Macro:

Delphi-Quellcode:
  ActiveWindow.Visible = False
    Windows("123.xls").Activate
    Range("A1").Select
Delphi:
Delphi-Quellcode:
 Excel.ActiveWindow.Visible := False;
 Excel.Windows('123.xls').Activate;
 Excel.Range('A1').Select;
Gibt aber immer den Fehler:
---------------------------
Member nicht gefunden.
---------------------------
  Mit Zitat antworten Zitat
Benutzerbild von toms
toms
(CodeLib-Manager)

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

Re: Excel Diagramm einfärben

  Alt 16. Feb 2005, 14:10
Hi,

Die "richtigen" Code findest du in hier]folgendem Source Code[/url]
Thomas
  Mit Zitat antworten Zitat
perle

Registriert seit: 8. Apr 2004
183 Beiträge
 
Delphi 7 Enterprise
 
#5

Re: Excel Diagramm einfärben

  Alt 16. Feb 2005, 14:18
versuch mal eckige- statt runde Klammern zu nehmen.
  Mit Zitat antworten Zitat
ueei.net

Registriert seit: 4. Mär 2004
Ort: Wels
53 Beiträge
 
#6

Re: Excel Diagramm einfärben

  Alt 16. Feb 2005, 14:44
Hallo,

hier die gesammelten Werke wie es nun wirklich funktioniert:


Erst mal Diagramm und Säule wählen dann Farbe ändern:

Delphi-Quellcode:
 Excel.ActiveSheet.ChartObjects['Diagramm 2'].Activate;
  Excel.ActiveChart.SeriesCollection(1).Select;
  Excel.ActiveChart.SeriesCollection(1).Points(1).Select;
  Excel.Selection.Interior.ColorIndex := 24;
Dann wieder zurück in eine Zelle, damit weitergearbeitet werden kann:

Delphi-Quellcode:
  Excel.ActiveWindow.Visible := False;
  Excel.Windows['meine.xls'].Activate;
  Excel.Range['A1'].Select;
Danke für eure Hilfe!

lg.
  Mit Zitat antworten Zitat
Antwort Antwort


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 16:41 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