AGB  ·  Datenschutz  ·  Impressum  







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

OpenOffice Zugriff Fehler

Ein Thema von Cyberdine · begonnen am 21. Mai 2012 · letzter Beitrag vom 21. Mai 2012
Antwort Antwort
Cyberdine

Registriert seit: 21. Mai 2012
26 Beiträge
 
#1

OpenOffice Zugriff Fehler

  Alt 21. Mai 2012, 09:29
Hallo zusammen,
wollte von meiner Delphi Anwendung aus Zugriff auf ein OpenOffice Dokument haben, um mal zu sehen wie sowas eigentlich geht und bischen experimentieren.

habe ein Teil hiervon verwendet -> http://www.delphipraxis.net/6940-kle...penoffice.html

Und das ganze sieht jetzt so aus, beim Ausführen kommt dann eine Execption Access Violation

Hier der Quelltext





Delphi-Quellcode:
unit Unit1;

interface

uses
  Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
  Vcl.Controls, Vcl.Forms, Vcl.Dialogs, comobj, Vcl.StdCtrls;

type

  TForm1 = class(TForm)
    e1: TEdit;
    M1: TButton;
    procedure e1Change(Sender: TObject);
    procedure M1Click(Sender: TObject);
  private
  protected
  public
  end;

  TOLE_OpenOffice = class(TObject)



  private
    { Private-Deklarationen }
      // Da OpenOffice Pfadangaben im Unixstyle haben will werden Backslashes umgewandelt
  function ToOOPfad(Pfad:String):String;


  protected
    // Das OLE-Objekt, die Desktopinstanz und das Dokument selbst.
  Service, Desktop, Document : Variant;


  public
    { Public-Deklarationen }
  // Erstellt ein OLE Objekt;
  function Connect: boolean;
  // Oeffnet eine neues Dokument
  function Open:boolean;OVERLOAD;
  // Laden eines forhandenen Dokuments
  function Open(datei:string):boolean;OVERLOAD;
  // Ein Bookmarkfeld ersetzen ( Nicht Case Sensitiv)
  function ErsetzeBookmark(name,inhalt:String):boolean;
  end;



var
  Form1: TForm1; // Zugriffsforumular
  TOffice : TOLE_OpenOffice; // Open Office Zugriffsobjekt


{$R *.dfm}


implementation

function TOLE_OpenOffice.Connect:boolean;
var
  rueckgabe : boolean;
begin
  try
    Service := CreateOleObject('com.sun.star.ServiceManager');
    Desktop := Service.createInstance('com.sun.star.frame.Desktop');
    rueckgabe := true;
  except
    rueckgabe := false;
  end;
  result := rueckgabe;
end;

function TOLE_OpenOffice.Open:boolean;
var
  rueckgabe : boolean;
begin
  try
    Document := Desktop.LoadComponentFromURL(
              'private:factory/swriter',
              '_blank',
              0,
              VarArrayCreate([0, - 1], varVariant));
    rueckgabe := true;
  except
    rueckgabe := false;
  end;
  result := rueckgabe;
end;

function TOLE_OpenOffice.Open(datei:string):boolean;
var
  rueckgabe : boolean;
begin
  datei := ToOOPfad(datei);
  try
    Document := Desktop.LoadComponentFromURL(
              datei,
              '_blank',
              0,
              VarArrayCreate([0, - 1], varVariant));
    rueckgabe := true;
  except
    rueckgabe := false;
  end;
  result := rueckgabe;
end;

function TOLE_OpenOffice.ToOOPfad(Pfad:String):String;
var
  rueckgabe : string;
  i : integer;
begin
  rueckgabe := 'file:///';
  while (POS('\',pfad)>0) do
  begin
    i := POS('\',pfad);
    delete(pfad,i,1);
    Insert('/',pfad,i);
  end;
  rueckgabe := rueckgabe + pfad;
  result := rueckgabe;
end;

function TOLE_OpenOffice.ErsetzeBookmark(name,inhalt:String):boolean;
var
  objtext, tc, bm, li : Variant;
  i : integer;
  rueckgabe : boolean;
begin
  rueckgabe := false;
  try
    objText := Document.getText;
    tc := objText.createTextcursor;
    li := Document.Bookmarks.getElementNames;
    for i := VarArrayLowBound(li,1) to VarArrayHighBound(li,1) do
    begin
      if (uppercase(li[i]) = uppercase(name)) then
      begin
        bm := Document.Bookmarks.getbyName(li[i]);
        tc := Document.Text.createTextCursorByRange(bm.Anchor);
        tc.string := inhalt;
        rueckgabe := true;
      end;
    end;
  except
    rueckgabe := false;
  end;
  result := rueckgabe;
end;


procedure TForm1.e1Change(Sender: TObject);
var str_tmp : string;
begin
  str_tmp := e1.Text;

end;

procedure TForm1.M1Click(Sender: TObject);
var str_tmp : string;
    bool_file : Boolean;


begin
  str_tmp := e1.Text;

  bool_file := TOffice.Connect;

// bool_file := TOffice.Open(str_tmp);

end;

end.

Geändert von MrSpock (21. Mai 2012 um 11:42 Uhr) Grund: Code Tags hinzugefügt.
  Mit Zitat antworten Zitat
Cyberdine

Registriert seit: 21. Mai 2012
26 Beiträge
 
#2

AW: OpenOffice Zugriff Fehler

  Alt 21. Mai 2012, 09:32
Der Fehler tritt übrigens genau hier auf

Service := CreateOleObject('com.sun.star.ServiceManager');
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.171 Beiträge
 
Delphi 10.4 Sydney
 
#3

AW: OpenOffice Zugriff Fehler

  Alt 21. Mai 2012, 09:56
Könnte mir vorstellen das Name nicht mehr passt und mittlerweilse was mit Oracle verwendet wird.

Und übrigens: Quellcode kann man auch formatiert darstellen lassen damit man es besser lesen kann. Einfach das Helm-Icon oben in der Toolbarleiste verwenden.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Cyberdine

Registriert seit: 21. Mai 2012
26 Beiträge
 
#4

AW: OpenOffice Zugriff Fehler

  Alt 21. Mai 2012, 10:27
Wenn ich das Helmsymbol anklicke, verschwindet der Cursor, hab dann den Quelltext reinkopiert, da kam aber nix.
Hab es dann so probiert, Helm anklicken, ins Textfenster rein den Quelltext posten und nochmal den Helm, war aber alles wieder beim alten.
Habs mit Firefox und IE ausprobiert.

Das mit OpenOffice wird schwierig, seh ich jetzt schon
  Mit Zitat antworten Zitat
Cyberdine

Registriert seit: 21. Mai 2012
26 Beiträge
 
#5

AW: OpenOffice Zugriff Fehler

  Alt 21. Mai 2012, 10:45
Also laut http://www.openoffice.org/udk/common...utomation.html
stimmen die Angaben noch, scheinbar gibt es irgendwie eine Kollision im Speicher zwischen TForm und den Zugriffsobjekt für OpenOffice, werde das ganze jetzt mal ohne TForm ausprobieren, obs vielleicht daran liegt.
  Mit Zitat antworten Zitat
Lemmy

Registriert seit: 8. Jun 2002
Ort: Berglen
2.366 Beiträge
 
Delphi 10.3 Rio
 
#6

AW: OpenOffice Zugriff Fehler

  Alt 21. Mai 2012, 11:28
Hi,

schon mal versucht ein

TOffice.Create;

vor dem Connect zu machen? Du verwendest hier eine Klasse und versuchst vor dem Erzeugen per TOffice.Connect eine Methode aufzurufen - das ist aber keine Klassenmethode - du brauchst erst ne entsprechende Instanz von TOffice

Grüße
  Mit Zitat antworten Zitat
Cyberdine

Registriert seit: 21. Mai 2012
26 Beiträge
 
#7

AW: OpenOffice Zugriff Fehler

  Alt 21. Mai 2012, 11:39
Hy Lemmy,
habe jetzt ein Create bei der Initialisierung des Forms gemacht

procedure TForm1.FormCreate(Sender: TObject);
begin
TOffice.Create;
end;

allerdings kommt gleich dort eine Exeption.
  Mit Zitat antworten Zitat
Lemmy

Registriert seit: 8. Jun 2002
Ort: Berglen
2.366 Beiträge
 
Delphi 10.3 Rio
 
#8

AW: OpenOffice Zugriff Fehler

  Alt 21. Mai 2012, 11:47
Hi,

sorry, ich habe mich verlesen. Du musst das so machen.


Delphi-Quellcode:

  TOffice:=TOLE_OpenOffice.Create;
dann kannst Du auf das Ding zugreifen

GRüße
  Mit Zitat antworten Zitat
Cyberdine

Registriert seit: 21. Mai 2012
26 Beiträge
 
#9

AW: OpenOffice Zugriff Fehler

  Alt 21. Mai 2012, 12:05
Super Danke Lemmy, die eine Zeile hat mir viel geholfen, jetzt läufts endlich ohne Execption
  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 03:50 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