AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein Ausführung einer Batch-Datei vs Befehl in Konsole
Thema durchsuchen
Ansicht
Themen-Optionen

Ausführung einer Batch-Datei vs Befehl in Konsole

Ein Thema von Perlsau · begonnen am 20. Aug 2014 · letzter Beitrag vom 20. Aug 2014
Antwort Antwort
Perlsau
(Gast)

n/a Beiträge
 
#1

Ausführung einer Batch-Datei vs Befehl in Konsole

  Alt 20. Aug 2014, 02:26
Mein Programm erzeugt eine Batch-Datei zur Ausführung. Gestern hat noch alles funktioniert, jetzt eben plötzlich nicht mehr. In der Batch-Datei steht folgendes:

D:\Coding\2009A\Recherche\Debug\BIN\osmconvert.exe D:\Coding\OSM\PBF\Länder\Afrika\botswana-latest.osm.pbf >D:\Coding\2009A\Recherche\Debug\BIN\OSM\Botswana. osm

Da wird also das Konsolenprogramm osmconvert mit zwei Parametern gestartet. Füge ich den Text der Batch-Datei in ein Konsolenfenster ein und drücke dann Enter, wird der Befehl ausgeführt und ich erhalte in Nullkommanix eine OSM-Datei mit ca. 128 MB. Führe ich im Explorer jedoch einen Doppelklick auf die Batch-Datei aus, wird die Zieldatei zwar erstellt, aber die Größe ist 0.

Das Space am Ende zwischen Botswana. und osm ist ein Darstellungsfehler des hiesigen Editors ...

Geändert von Perlsau (20. Aug 2014 um 02:29 Uhr) Grund: Ergänzung
  Mit Zitat antworten Zitat
Perlsau
(Gast)

n/a Beiträge
 
#2

gelöst

  Alt 20. Aug 2014, 03:10
Nach einer frühen Tasse Kaffee ist mir klargeworden, daß die Batch-Datei irgendwie mit den Umlauten nicht klarkommt. Nachdem ich daraufhin den Order Länder in Staaten umbenannt habe, funktioniert die Batchdatei tadellos.
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.270 Beiträge
 
Delphi 10.4 Sydney
 
#3

AW: Ausführung einer Batch-Datei vs Befehl in Konsole

  Alt 20. Aug 2014, 05:20
Hallo


Ansi <> OEM

also AnsiToOem benutzen.

Heiko
Heiko
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#4

AW: Ausführung einer Batch-Datei vs Befehl in Konsole

  Alt 20. Aug 2014, 08:06
Ist es nicht immer wieder schön, über die eingebauten Inkompatibilitäten zu stolpern?
Solange bei Umlauten das Problem des Datenhackfleisches besteht, beschränkt man sich halt auf A..Z und _

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
Benutzerbild von Sherlock
Sherlock

Registriert seit: 10. Jan 2006
Ort: Offenbach
3.763 Beiträge
 
Delphi 11 Alexandria
 
#5

AW: Ausführung einer Batch-Datei vs Befehl in Konsole

  Alt 20. Aug 2014, 08:08
Man braucht sich nicht beschränken, Delphi-Referenz durchsuchenAnsiToOEM macht was es soll, so lange man keine "uneuropäischen" Zeichen verwendet.

Sherlock
Oliver
Geändert von Sherlock (Morgen um 16:78 Uhr) Grund: Weil ich es kann
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Ausführung einer Batch-Datei vs Befehl in Konsole

  Alt 20. Aug 2014, 08:14
Oder den kurze 8.3-Namen dieses Verzeichnisses oder im ganzen Pfad verwenden.

Wenn es im OEM-Zeichensatz das gewünschte Zeichen nicht gibt, dann lässt es sich sowieso nicht umwensen.
Und er hat ein Unicode-Delphi, womit ANSI sowieso nicht direkt geht, da er dann nocheine zweite Umwandlung hätte. (aka Google-Translate: deutsch->chineisch->englisch )

AnsiToOem ist nicht so gut und selbt Microsoft sagt dazu.
[OH="MSDN (.Net)"]Wird nur aus Gründen der Abwärtskompatibilität bereitgestellt. Verwenden Sie stattdessen die GETCP( )-Funktion[/OH]

In der WinAPI wäre es Delphi-Referenz durchsuchenCharToOem (CharToOemW) und auch da sollte man etwas aufpassen.
Zitat von MSDN:
Warning Do not use. See Security Considerations.
[add] MSDN-Library durchsuchenAnsiToOemBuffW, MSDN-Library durchsuchenCharToOemBuffW


Man könnte auch mit Delphi-Referenz durchsuchenSetFileApisToOEM rumspielen und schauen was dabei in der Datei landet,
oder man nimmt den aktuellen Weg, um die Codepage umzuwandeln. (WideCharToMultiByte mit CP_OEMCP)
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  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 21:55 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