Hallo Gerhard,

"[...] dass wohl alles ohne das Zeichen funktioniert. [...]" stimmt mittlerweile (nach weiteren Test meinerseits) nicht mehr.

Um das angehängte "#" als Typ-Deklarationszeichen geht es gar nicht mehr, sondern:

Wenn im "Ausdruck" für "Print" ein "#" vorkommt, dann MUSS im "Ausdruck" für "Print " irgendwo vor dem "#" ein " " sein, ansonsten gibt's eine Syntaxfehler-Fehlermeldung:

Sub Print_To_Output
Dim VarDouble#
Dim Pfad_Datei As String
Dim Datenkanal As Integer
VarDouble# = 0.123123
Pfad_Datei = "E:\TMP\Output.txt"
Datenkanal = Freefile
Open Pfad_Datei For Output As #Datenkanal
Print #Datenkanal," VarDouble# = ",VarDouble# ' O.K.
'Print #Datenkanal,"VarDouble# = ",VarDouble# ' ERROR
Print #Datenkanal," ABC#DEF" ' O.K.
Print #Datenkanal,"AB C#D EF" ' O.K.
Print #Datenkanal," ","ABC#DEF" ' O.K.
'Print  #Datenkanal,"ABC#DEF" ' ERROR
'Print #Datenkanal,"ABC#D EF" ' ERROR
Close #Datenkanal
End Sub

Wenn das kein BasicCompiler-Fehler ist ...

Viele Grüße
Hans-Werner :-))



------ Originalnachricht ------
Von: "Gerhard Weydt" <gerhard.we...@t-online.de>
An: users@de.libreoffice.org
Gesendet: 22.08.2020 15:51:04
Betreff: Re: [de-users] Makro Basic - Ausgabe in Datei - DoubleVariable via Typ-Deklarationszeichen # - Makro-Fehler-Abbruch

Hallo Hans-Werner,

wenn etwas bei Pitonyak steht, ist es deshalb auch nicht besser begründet als 
bei den anderen Quellen, die du genannt hast, auch beschreibt das, was er 
feststellen konnte und nicht, was er selbst aus dem Compiler-Code ermittelt 
hätte; ich bin mir ziemlich sicher, dass ich eine entsprechende Aussage von ihm 
selbst einmal gelesen habe. Ob die ursprüngliche Idee war, dass das ürzel nach 
dem eigentlichen Namen dazugehört oder nur für die Deklaration gebraucht wird, 
können wir kaum entscheiden, für letzteres spricht aber die Tasache, dass wohl 
alles ohne das Zeichen funktioniert.
Und auch der folgende Text zu Microsofts Visual Basic geht in die gleiche 
Richtung:

In addition to specifying a data type in a declaration statement, you can force 
the data type of some programming elements with a /type character/. The type 
character must immediately follow the element, with no intervening characters 
of any kind.

The type character is not part of the name of the element. An element defined 
with a type character can be referenced without the type character.

Wenn man das Ende wörtlich nehmen darf, dann ist die Hinzufügung des Kürzels 
erlaubt, aber nicht nötig. In diesem Sinn wäre natürlich die Fehlermeldung bei 
der Double-Variable ein Fehler, aber mir geht es wie dir, ich mag diese Kürzel 
nicht und verwende sie nicht, ich weiß auch nicht recht, warum sie eingeführt 
wurden, vielleicht noch zu Lochkartenzeiten, wo man dann weniger Karten 
brauchte, so wie das Unterbringen mehrerer Befehle in einer Zeile durch die 
Trennung mit dem Doppelpunkt?

Was mich betrifft, würde ich es nicht für nötig halten, das als Fehler zu 
melden.

Viele Grüße

Gerhard



Am 22.08.2020 um 15:23 schrieb OoOHWHOoO:
Hallo Gerhard,

so wie's ausschaut, hat das "Print" (und auch das "Write") - beziehungsweise der Compiler - beim 
"Print"/"Write" in eine Datei "sein Kreuz mit dem Doppelkreuz" ;-)) ...

Völlig unabhängig von einer Double-Variablen der Art "VarDouble#":

Im Zusammenhang mit "#" muss das erste Zeichen in der auszugebenden Zeichenkette ein 
" " (Leerzeichen) sein.

Fehlt dieses Leerzeichen, meldet der Compiler den Syntax-Fehler "Unzulässiger Wert 
oder Datentyp.Datentypen unverträglich." !

Sub Print_To_Output
Dim Pfad_Datei As String
Dim Datenkanal As Integer
Pfad_Datei = "E:\TMP\Output.txt"
Datenkanal = Freefile
Open Pfad_Datei For Output As #Datenkanal
Print #Datenkanal," #"
Close #Datenkanal
End Sub

Einen kleinen Hinweis, dass das "#" bei Print/Write in eine Datei "eine besondere 
Rolle spielt" könnte eine Textpassage bei Pitonyak liefern, wobei die internen Zusammenhänge 
völlig im Dunkeln liegen, da muss man schon den Compiler-SourceCode kennen:

8.8. Daten aus einer Datei lesen und in eine Datei schreiben
Um Daten in Dateien zu schreiben oder aus Dateien zu lesen, die im Modus Random 
oder Binary geöffnet wurden, verwenden Sie die Anweisungen Put und Get. Für 
jeden anderen Modus verwenden Sie die Anweisungen Line Input, Print und Write. 
Wenn keine Eingabedaten angegeben sind, wird eine Leerzeile in die Datei 
geschrieben. Die Anweisung Write akzeptiert mehrere Argumente zur Eingabe und 
fügt beim Schreiben automatisch Trennzeichen ein. In der Datei werden die 
Eingabeausdrücke voneinander durch Kommas getrennt, Zeichenketten werden in 
doppelte Anführungszeichen gesetzt, Zahlen werden nicht gekennzeichnet, und 
Datums- sowie boolesche Werte werden zwischen Doppelkreuze (#) gesetzt. Zahlen 
mit Dezimaltrennzeichen werden gemäß dem eingestellten Gebietsschema 
konvertiert.

https://www.uni-due.de/~abi070/count.php?id=OOME_3_0_deutsch.pdf

Warum bei dem "Print", wenn nicht in eine Datei, das "Warnung"-Symbol verbunden mit dem Text 
"Warnung" ausgegeben wird, ist nicht nach vollziehbar, denn es passiert auch bei dem sehr einfachen Beispiel 
in der "LibreOffice Hilfe":

Sub ExamplePrint
Print "ABC"
Print "ABC","123"
i = FreeFile()
Open "C:\Temp.txt" For Output As i
Print #i, "ABC"
Close #i
End Sub

Grüße
Hans-Werner :-))



-- Liste abmelden mit E-Mail an: users+unsubscr...@de.libreoffice.org
Probleme? 
https://de.libreoffice.org/hilfe-kontakt/mailing-listen/abmeldung-liste/
Tipps zu Listenmails: https://wiki.documentfoundation.org/Netiquette/de
Listenarchiv: https://listarchives.libreoffice.org/de/users/
Datenschutzerklärung: https://www.documentfoundation.org/privacy
--
Liste abmelden mit E-Mail an: users+unsubscr...@de.libreoffice.org
Probleme? 
https://de.libreoffice.org/hilfe-kontakt/mailing-listen/abmeldung-liste/
Tipps zu Listenmails: https://wiki.documentfoundation.org/Netiquette/de
Listenarchiv: https://listarchives.libreoffice.org/de/users/
Datenschutzerklärung: https://www.documentfoundation.org/privacy

Antwort per Email an