AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein GUI-Design mit VCL / FireMonkey / Common Controls Delphi-Only Read(Writer) für Excel-Dokumente (xls/xlsx)
Thema durchsuchen
Ansicht
Themen-Optionen

Delphi-Only Read(Writer) für Excel-Dokumente (xls/xlsx)

Ein Thema von Bernhard Geyer · begonnen am 30. Apr 2018 · letzter Beitrag vom 2. Mai 2018
 
Delphi.Narium

Registriert seit: 27. Nov 2017
2.602 Beiträge
 
Delphi 7 Professional
 
#5

AW: Delphi-Only Read(Writer) für Excel-Dokumente (xls/xlsx)

  Alt 30. Apr 2018, 17:35
Schau mal bitte hier den vierten Betrag an: https://stackoverflow.com/questions/...t-having-excel

Das könnte eventuell eine Lösung sein, die man sich relativ schnell selbst bauen kann.

Ist letztlich "nur" 'ne HTML-Datei mit der Endung xls.

Excel kann damit umgehen und für einen reinen Datenaustausch könnte das durchaus reichen.

Eine Minimalversion in Pascalsacript für meinen Editor sieht so aus:
Delphi-Quellcode:
program Test;

procedure CreateXLS(ADataSet: TDataSet; AFileName : String; ASheetName : String);
var
        i : Integer;
        sl : TStringList;
begin
  sl := TStringList.Create;
  sl.Add('<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns="http://www.w3.org/TR/REC-html40">');
  sl.Add('<head>');
  sl.Add('<meta http-equiv="Content-Type" content="text/html; charset=windows-1252">');
  sl.Add('<!--[if gte mso 9]>');
  sl.Add('<xml>');
  sl.Add(' <x:ExcelWorkbook>');
  sl.Add(' <x:ExcelWorksheets>');
  sl.Add(' <x:ExcelWorksheet>');
  sl.Add(Format(' <x:Name>%s</x:Name>',[ASheetName]));
  sl.Add(' <x:WorksheetOptions>');
  sl.Add(' <x:Selected/>');
  sl.Add(' <x:Panes>');
  sl.Add(' <x:Pane>');
  sl.Add(' <x:Number>1</x:Number>');
  sl.Add(' <x:ActiveRow>1</x:ActiveRow>');
  sl.Add(' </x:Pane>');
  sl.Add(' </x:Panes>');
  sl.Add(' <x:ProtectContents>False</x:ProtectContents>');
  sl.Add(' <x:ProtectObjects>False</x:ProtectObjects>');
  sl.Add(' <x:ProtectScenarios>False</x:ProtectScenarios>');
  sl.Add(' </x:WorksheetOptions>');
  sl.Add(' </x:ExcelWorksheet>');
  sl.Add(' </x:ExcelWorksheets>');
  sl.Add(' </x:ExcelWorkbook>');
  sl.Add('</xml>');
  sl.Add('<![endif]-->');
  sl.Add('</head>');
  sl.Add('<body>');
  sl.Add('<table x:str>');
  ADataSet.First;
  while not ADataSet.EoF do begin
    sl.Add('<tr>');
    for i := 0 to ADataSet.Fields.Count - 1 do sl.Add(Format('<td x:num>%s</td>',[ADataSet.Fields.Fields[i].AsString]));
    sl.Add('</tr>');
    ADataSet.Next;
  end;
  sl.Add('</table>');
  sl.Add('</body>');
  sl.Add('</html>');
  sl.SaveToFile(AFileName);
  sl.Free;
end;

begin
  CreateXLS(DataSet,'c:\temp\Dateiname.xls','Sheetname');
end.
Excel kann die daraus resultierende Datei problemlos öffnen.
  Mit Zitat antworten Zitat
 


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 11:59 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-2025 by Thomas Breitkreuz