AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Delphi minni while schleife auf geschwindigkeit optimieren
Thema durchsuchen
Ansicht
Themen-Optionen

minni while schleife auf geschwindigkeit optimieren

Ein Thema von Cyberstorm · begonnen am 27. Jan 2009 · letzter Beitrag vom 27. Jan 2009
Antwort Antwort
Cyberstorm

Registriert seit: 23. Okt 2003
159 Beiträge
 
Delphi 2010 Architect
 
#1

minni while schleife auf geschwindigkeit optimieren

  Alt 27. Jan 2009, 19:22
hi. ich will aus einer html seite alle tags löschen --> alle sachen wie <Table blablabla> usw. löschen.

meine schleife funktioniert soweit aber ist mir zu lahm bei längeren seiten.
wie kann ich den code auf geschwindigkeit optimieren?

Delphi-Quellcode:
var
  first: Integer;
  htmlString: String;
begin
  //htmlStringzuweisen
  first:=1;
  while first > 0 do
    begin
      first:=Pos('<', htmlString);
      Delete(htmlString, first, pos('>', htmlString) - first + 1);
    end;
end;
  Mit Zitat antworten Zitat
Namenloser

Registriert seit: 7. Jun 2006
Ort: Karlsruhe
3.724 Beiträge
 
FreePascal / Lazarus
 
#2

Re: minni while schleife auf geschwindigkeit optimieren

  Alt 27. Jan 2009, 19:35
Delphi-Quellcode:
function StripHTMLTags(const HTML: string): string;
var
  TagDepth: integer;
  i: integer;
  ResultIndex: integer;
begin
  TagDepth := 0;
  ResultIndex := 1;
  SetLength(result, length(HTML));
  for i := 1 to length(HTML) do
  begin
    case HTML[i] of
    '<': inc(TagDepth);
    '>': dec(TagDepth); // ggf. hier prüfen, ob der Tag überhaupt schon geöffnet wurde (TagDepth > 0)
    else
      if TagDepth > 0 then
      begin
        result[ResultIndex] := HTML[i];
        inc(ResultIndex);
      end;
    end;
  end;
  SetLength(result, ResultIndex);
end;
Im Antwortfenster aus dem Kopf getippt - ich kann daher nicht garantieren, dass es funktioniert. Der Ansatz ist einfach, einen String mit der gleichen Länge wie dem ursprungsstring zu erstellen (länger kann das Ergebnis ja nicht sein). Anschließend wird jedes Zeichen in einer Schleife in den Ergebnisstring übertragen, wenn nicht ein oder mehrere Tags geöffnet sind. Am Ende wird der String noch zu recht gestutzt.

Das ist aber nur eine einfache Methode, die man besser nicht auf allzu invaliden HTML-Code loslassen sollte. Wenn man auf Nummer sicher gehen will/muss, sollte man besser einen Parser verwenden.
  Mit Zitat antworten Zitat
Cyberstorm

Registriert seit: 23. Okt 2003
159 Beiträge
 
Delphi 2010 Architect
 
#3

Re: minni while schleife auf geschwindigkeit optimieren

  Alt 27. Jan 2009, 19:51
vielen dank.

der code ist um einiges schneller!
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
43.166 Beiträge
 
Delphi 12 Athens
 
#4

Re: minni while schleife auf geschwindigkeit optimieren

  Alt 27. Jan 2009, 20:00
nur mal ein kleiner Hinweis zum ursprünglichem Code:

bei z.B. diesem String "abc>def<xyz>" wär dein Code schön in einer Endlosschleife gelandet
statt dem Pos im Delete hättest du eher 'nen PosEx verwenden sollen.
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  Mit Zitat antworten Zitat
Cyberstorm

Registriert seit: 23. Okt 2003
159 Beiträge
 
Delphi 2010 Architect
 
#5

Re: minni while schleife auf geschwindigkeit optimieren

  Alt 27. Jan 2009, 20:12
Zitat von himitsu:
nur mal ein kleiner Hinweis zum ursprünglichem Code:

bei z.B. diesem String "abc>def<xyz>" wär dein Code schön in einer Endlosschleife gelandet
statt dem Pos im Delete hättest du eher 'nen PosEx verwenden sollen.
wohl wahr, danke.


in dem code wahr noch ein kleiner fehler.
"SetLength(result, ResultIndex);" <-- da mussnoch 1 vom ResultIndex abgezogen werden, da ja nach dem letzten zeichen nochmal inkrementiert wird.

hier nochmal korrigiert:

Delphi-Quellcode:
function StripHTMLTags(const HTML: String): String;
var
  TagDepth, i, ResultIndex: Integer;
begin
  TagDepth:=0;
  ResultIndex:=1;
  SetLength(result, length(HTML));
  for i:=1 to length(HTML) do
    begin
        case HTML[i] of
          '<': inc(TagDepth);
          '>': if TagDepth > 0 then dec(TagDepth);
          else if TagDepth = 0 then
            begin
              result[ResultIndex]:=HTML[i];
              inc(ResultIndex);
            end;
        end;
    end;
  SetLength(result, ResultIndex - 1);
end;
  Mit Zitat antworten Zitat
Namenloser

Registriert seit: 7. Jun 2006
Ort: Karlsruhe
3.724 Beiträge
 
FreePascal / Lazarus
 
#6

Re: minni while schleife auf geschwindigkeit optimieren

  Alt 27. Jan 2009, 20:20
Ich merke gerade, dass man sich das ganze Inkrementieren und Dekrementieren eigentlich sparen kann. Eine Boolean-Variable würde es auch tun, denn in einem Tag kann ja ein zweiter nicht anfangen (es sei denn der Code ist echt vermurkst Frontpage). Stattdessen sollte man lieber auf sowas achten:
Code:
<a b='[color=#ff0000]>[/color]'>
Für die entsprechende Behandlung dieses Problems wird dann aber doch wieder ein Zähler nötig sein (oder ein Stack, auf dem man die Zeichen ablegt?).
  Mit Zitat antworten Zitat
mr_emre_d
(Gast)

n/a Beiträge
 
#7

Re: minni while schleife auf geschwindigkeit optimieren

  Alt 27. Jan 2009, 20:32
mini
-.-
  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 01:02 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