AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken wie Adresse auseinandernehmen
Thema durchsuchen
Ansicht
Themen-Optionen

wie Adresse auseinandernehmen

Ein Thema von khh · begonnen am 5. Sep 2012 · letzter Beitrag vom 7. Sep 2012
Antwort Antwort
Seite 1 von 3  1 23      
khh

Registriert seit: 18. Apr 2008
Ort: Südbaden
1.929 Beiträge
 
FreePascal / Lazarus
 
#1

wie Adresse auseinandernehmen

  Alt 5. Sep 2012, 13:24
Datenbank: Firebird • Version: 2.1 • Zugriff über: zeos
hallo zusammen
ich habe in einem Feld Adressdaten wie folgt:

Auf dem Eifelturm 1
Schlossberg 12
Hauptstr. 62-64

ich möchte die Hausnummern separat speichern.

Jemand ne Idee, wie ich das hinbekomme?
Mein Ansatz wäre per stringreplace ein sonderzeichen einzufügen und dann dort zu trennen.
Aber weiter stehe ich grad auf dem Schlauch

Ich danke euch
khh
Karl-Heinz
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: wie Adresse auseinandernehmen

  Alt 5. Sep 2012, 13:25
Oder den letzten Block abtrennen
Markus Kinzler
  Mit Zitat antworten Zitat
khh

Registriert seit: 18. Apr 2008
Ort: Südbaden
1.929 Beiträge
 
FreePascal / Lazarus
 
#3

AW: wie Adresse auseinandernehmen

  Alt 5. Sep 2012, 13:26
Oder den letzten Block abtrennen
ja, aber wie ?
Karl-Heinz
  Mit Zitat antworten Zitat
Grolle

Registriert seit: 5. Nov 2004
Ort: Coesfeld
1.268 Beiträge
 
Delphi 2010 Professional
 
#4

AW: wie Adresse auseinandernehmen

  Alt 5. Sep 2012, 13:30
Mit Hier im Forum suchenpos und Hier im Forum suchencopy?

  Mit Zitat antworten Zitat
Benutzerbild von Bummi
Bummi

Registriert seit: 15. Jun 2010
Ort: Augsburg Bayern Süddeutschland
3.470 Beiträge
 
Delphi XE3 Enterprise
 
#5

AW: wie Adresse auseinandernehmen

  Alt 5. Sep 2012, 13:35
Per Delphi?

Durchlaufen bis zum ersten ['0'..'9'] , ab da als Hausnummer behandeln ?
Thomas Wassermann H₂♂
Das Problem steckt meistens zwischen den Ohren
DRY DRY KISS
H₂ (wenn bei meinen Snipplets nichts anderes angegeben ist Lizenz: WTFPL)
  Mit Zitat antworten Zitat
Benutzerbild von Nersgatt
Nersgatt

Registriert seit: 12. Sep 2008
Ort: Emlichheim
693 Beiträge
 
Delphi 10.1 Berlin Professional
 
#6

AW: wie Adresse auseinandernehmen

  Alt 5. Sep 2012, 13:37
Durchlaufen bis zum ersten ['0'..'9'] , ab da als Hausnummer behandeln ?
Und hoffen, dass niemand an der "Straße des 17. Juni" wohnt....
Jens
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#7

AW: wie Adresse auseinandernehmen

  Alt 5. Sep 2012, 13:37
Oder per TStringList.

Delphi-Quellcode:
var
  sl: TStrings;
  ...
  sl := TStringList.Create;
  sl.Delimiter := ' ';
  sl.DelimitedText := <Str mit Hausnummer>;
  <hausnummer> := sl[sl.Count-1];
  sl.Delete( sl.Count-1);
  <str> := sl.Text;
  ..
  sl.Free;
Markus Kinzler
  Mit Zitat antworten Zitat
khh

Registriert seit: 18. Apr 2008
Ort: Südbaden
1.929 Beiträge
 
FreePascal / Lazarus
 
#8

AW: wie Adresse auseinandernehmen

  Alt 5. Sep 2012, 13:37
Per Delphi?

Durchlaufen bis zum ersten ['0'..'9'] , ab da als Hausnummer behandeln ?

warum kommt man auf die einfachsten Dinge nicht selbst
EDIT : mh die Straße des 17. Juni sollte manuell zu finden sein

ich danke dir / euch
Karl-Heinz
  Mit Zitat antworten Zitat
Benutzerbild von uligerhardt
uligerhardt

Registriert seit: 19. Aug 2004
Ort: Hof/Saale
1.746 Beiträge
 
Delphi 2007 Professional
 
#9

AW: wie Adresse auseinandernehmen

  Alt 5. Sep 2012, 13:39
Grobe Idee:
  1. Den String rückwärts nach dem ersten Whitespace (Leerzeichen, Tab etc.) durchsuchen.
  2. Alles dahinter (also 1, 12 bzw. 62-64 in deinen Beispielen) in eine StringList mit Delimiter '-' stecken.
  3. Bei allen Elementen der StringList prüfen, ob sie eine Hausnummer sind, also z.B. nur aus Ziffern und evtl. hintendran einem Buchstaben ("Schlossberg 12a") bestehen.
  4. Falls ja, den Kandidaten aus Schritt 1 akzeptieren.
False positives und negatives wirst du nicht vermeiden können. Und ob du jetzt "Schlossberg 12 1/2" behandeln willst oder "Schlossberg 12, 3. Stock"...
Uli Gerhardt

Geändert von uligerhardt ( 5. Sep 2012 um 13:42 Uhr)
  Mit Zitat antworten Zitat
khh

Registriert seit: 18. Apr 2008
Ort: Südbaden
1.929 Beiträge
 
FreePascal / Lazarus
 
#10

AW: wie Adresse auseinandernehmen

  Alt 5. Sep 2012, 13:39
Oder per TStringList.

Delphi-Quellcode:
var
  sl: TStrings;
  ...
  sl := TStringList.Create;
  sl.Delimiter := ' ';
  sl.DelimitedText := <Str mit Hausnummer>;
  <hausnummer> := sl[sl.Count-1];
  sl.Delete( sl.Count-1);
  <str> := sl.Text;
  ..
  sl.Free;
ich probiers erst mal so
EDIT: funktioniert (fast)einwandfrei.
die Leerzeichen zwischen den Strassennahmen die aus mehreren Wörtern bestehen werden eliminiert
ich danke euch
Karl-Heinz

Geändert von khh ( 5. Sep 2012 um 13:59 Uhr)
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23      


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 04:21 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