AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein Daten von Excel über das Clipboard in AdvStringgrid einfügen
Thema durchsuchen
Ansicht
Themen-Optionen

Daten von Excel über das Clipboard in AdvStringgrid einfügen

Ein Thema von norwegen60 · begonnen am 10. Mai 2019 · letzter Beitrag vom 10. Mai 2019
Antwort Antwort
norwegen60

Registriert seit: 23. Dez 2007
Ort: Schwarzwald
505 Beiträge
 
Delphi 12 Athens
 
#1

Daten von Excel über das Clipboard in AdvStringgrid einfügen

  Alt 10. Mai 2019, 16:54
Hallo zusammen,

es ist kein Problem, einen markierten Excel-Bereich per Ctrl-C / Ctrl-V in ein bestehendes TAdvStringGrid zu kopieren. Über OnBeforePasteClipboardCell will ich sicherstellen, dass nur zulässige Daten kopiert werden.
Zwei Probleme für die meine Lösung nicht funktioniert und wo ich keine Lösung habe:
  • Einfügen soll nur möglich sein, wenn sich Anwendung im EditMode befindet. Wenn ich das so mache wie unten, kommt mir für jedes Feld im Clipboard diese Meldung. Ich möchte sie natürlich nur für das gesamte Clipboard einmal
  • Dringlicher ist das Problem, dass automatische eine neue Zeile ans Grid angehängt wird, bevor dieser Aufruf kommt. Von daher ist die Abfrage  (ARow < sgGrid.RowCount) immer erfüllt.
Hier meine Überprüfung:
Delphi-Quellcode:
procedure TfrmTestgrid.sgDataClipboardBeforePasteCell(Sender: TObject; ACol, ARow: Integer; var Value: string; var Allow: boolean);
// *****************************************************************************************************************************************
var
  rValue: Double;

begin
// if not bEditMode and btEdit.Enabled then
// M_Messagedlg('Copy&Paste is only possible in Edit mode.', mtConfirmation, [mbOK], 0);

  Allow := bEditMode and // Editierung muss aktiviert sein
    (sgGrid.Col in [6 .. 12]) and (sgGrid.Col > 0) and // Cursor muss in editierbarem Bereich stehen
    (ACol in [6 .. 12]) and (ARow > 0) and // Zielzelle muss in editierbarem Bereich liegen
    (ARow < sgGrid.RowCount) and // Nur so viele Zeilen wie schon vorhanden füllen
    TryStrToFloat(sgGrid.Cells[ACol, ARow], rValue) and // Zielzelle muss bereits Zahl enthalten
    TryStrToFloat(Value, rValue); // Kopierter Wert muss Zahl sein
end;
Danke für jeden Lösungsvorschlag

Grüße
Gerd
  Mit Zitat antworten Zitat
peterbelow

Registriert seit: 12. Jan 2019
Ort: Hessen
702 Beiträge
 
Delphi 12 Athens
 
#2

AW: Daten von Excel über das Clipboard in AdvStringgrid einfügen

  Alt 10. Mai 2019, 19:10
Du machst deine Tests eventuell zu spät. Realisiere die Paste-Funktion über eine TAction, dann kannst Du die Tests im OnUpdate-Event der Action machen und die Action disablen wenn der Inhalt der Zwischenablage nicht deinen Anforderungen entspricht oder der momentane Kontext in der Anwendung nicht paßt.
Peter Below
  Mit Zitat antworten Zitat
norwegen60

Registriert seit: 23. Dez 2007
Ort: Schwarzwald
505 Beiträge
 
Delphi 12 Athens
 
#3

AW: Daten von Excel über das Clipboard in AdvStringgrid einfügen

  Alt 10. Mai 2019, 19:19
Hallo,

ich habe doch noch Lösungen gefunden
  • Das Einfügen fange ich im OnKeydown-Ereignis ab wo ich auf Ctrl-V prüfe
  • Gegen das Anlegen von Zeilen gibt es die Eigenschaft Navigation.AllowClipBoardRowGrow. In Navigation hatte ich zuvor nicht gesucht.

Danke trotzdem für deinen Lösungsansatz

Grüße
Gerd
  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 19:34 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