[NEWSboard IBMi Forum]

Hybrid View

  1. #1
    Registriert seit
    Mar 2002
    Beiträge
    5.287
    nö, dann wird nicht konvertiert (RTFM).
    AS400 Freeware
    http://www.bender-dv.de
    Mit embedded SQL in RPG auf Datenbanken von ADABAS bis XBASE zugreifen
    http://sourceforge.net/projects/appserver4rpg/

  2. #2
    Registriert seit
    Sep 2018
    Beiträge
    94
    Genau!!! Dann wird nicht konvertiert!!

    habe das "Programm" umgeschrieben:

    Flags = O_WRONLY + O_CREAT + O_APPEND + O_CCSID +O_TEXTDATA;
    Mode = S_IRWXU + S_IRWXG + S_IRWXO;
    Fd = Open(%Trim(txt_file):Flags:Mode:1252);

    Danach 3 Zeilen geschrieben:

    eval line1 = *blanks
    eval line = 'äüöß 1. Zeile'
    eval line1 = line + crlf
    callp write(fd: %addr(line1): %size(line1))

    ...


    Ergebnis:

    ÀÐj¡@@@@ñK@é…‰“…@@@@@@@@@@@@@@
    %JZà¡@@@@òK@é…‰“…@@@@@@@@@@@@@@
    %JZà¡„„„@óK@é…‰“…@@@@@@@@@@@@@@
    %

  3. #3
    Registriert seit
    Feb 2001
    Beiträge
    20.254
    Dann probier mal noch bitte folgendes:

    When the O_TEXT_CREAT flag and its prerequisite flags are not set, the specified or derived CCSID is the CCSID in which data is to be returned (when reading from a file), or the CCSID in which data is being supplied (when writing to a file).

    Mit der Interpretation, dass dies Binary-Mode ist.

    https://www.ibm.com/support/knowledg...htm#HDRIFSCCSD
    Dienstleistungen? Die gibt es hier: http://www.fuerchau.de
    Das Excel-AddIn: https://www.ftsolutions.de/index.php/downloads
    BI? Da war doch noch was: http://www.ftsolutions.de

  4. #4
    Registriert seit
    Sep 2018
    Beiträge
    94
    Du meinst das O_TEXT_CREAT flag einfach weglassen?

  5. #5
    Registriert seit
    Feb 2001
    Beiträge
    20.254
    Nein, hinzufügen. Das ist nicht zu verwechseln mit O_TEXTDATA.
    Es ist halt immer etwas schwierig, die englische Doku zu verstehen.
    Es ist schon seltsam, dass bei der O_CREAT für die Textumwandlung O_TEXT_CREAT erforderlich ist wobei bei bestehenden Dateien O_TEXTDATA bereits ausreicht.
    Dienstleistungen? Die gibt es hier: http://www.fuerchau.de
    Das Excel-AddIn: https://www.ftsolutions.de/index.php/downloads
    BI? Da war doch noch was: http://www.ftsolutions.de

  6. #6
    Registriert seit
    Sep 2018
    Beiträge
    94
    Klar! Wer lesen kann....

    Hatte den Wert verwechselt!!!


    Flags = O_WRONLY + O_CREAT + O_APPEND + O_CCSID +O_TEXTDATA +
    O_TEXT_CREAT;
    Mode = S_IRWXU + S_IRWXG + S_IRWXO;
    Fd = Open(%Trim(txt_file):Flags:Mode:1252);



    Fd liefert mir den Wert -1 (= Fehler)!

    Verstehe nicht warum.

    Im Code gibt es zwar den Hinweis:

    Note: O_TEXT_CREAT requires all of the following flags to work:
    O_CREAT+O_TEXTDATA+(O_CODEPAGE or O_CCSID)

    Alle Werte sind ja angegeben (Außer O_CCSID) aber es heißt ja: OR

  7. #7
    Registriert seit
    Jul 2001
    Beiträge
    2.646
    Zitat Zitat von Frankk Beitrag anzeigen
    Alle Werte sind ja angegeben (Außer O_CCSID) aber es heißt ja: OR
    Bei mathematischen Flags sollte man das "OR" eher als "plus" sehen, nicht als das (meist implizierte) "exklusiv-oder". Da kommt man schon mal durcheinander ;-)
    www.RZKH.de
    IBM Champion 2022, 2023, 2024
    IBM i Community Advocate https://www.youracclaim.com/badges/6...c-7ad4ba147af6
    Common / CEAC
    http://pub400.com

  8. #8
    Registriert seit
    Feb 2001
    Beiträge
    20.254
    Beachte im obigen Link den 5. Parameter "text file creation conversion ID".

    Laut Beschreibung wäre das die CCSID die dein Programm benötigt. Was ich allerdings für blödsinn halte, wenn ich die erst aus dem Job lesen muss.
    Allerdings könnte ich da dann auch z.B. 1200 für die Unicodefelder direkt angeben.

    In den Beispielen findet man dann allerdings wieder beide Versionen:
    1. Beispiel: Open => Close => Open => Write => Close
    2. Beispiel: Open => write => CLose.

    Beim 2. Beispiel wäre interessant, was bei CCSID 0 im 5. Parameter passiert, Fehler oder Job-CCSID?
    Dienstleistungen? Die gibt es hier: http://www.fuerchau.de
    Das Excel-AddIn: https://www.ftsolutions.de/index.php/downloads
    BI? Da war doch noch was: http://www.ftsolutions.de

  9. #9
    Registriert seit
    Sep 2018
    Beiträge
    94
    Habe folgendes zu diesem Thema nochmals ausprobiert:

    Flags = O_WRONLY + O_CREAT + O_APPEND + O_CCSID +O_TEXTDA
    O_CODEPAGE + O_TEXT_CREAT;
    Mode = S_IRWXU + S_IRWXG + S_IRWXO;
    Fd = Open(%Trim(txt_file):Flags:Mode:1252);

    Ergebnis: Fehler (Fd= -1)

    auch

    Flags = O_WRONLY + O_CREAT + O_APPEND + O_CCSID +O_TEXTDATA +
    O_TEXT_CREAT;
    Mode = S_IRWXU + S_IRWXG + S_IRWXO;
    Fd = Open(%Trim(txt_file):Flags:Mode:0);

    lieferte nur einen Fehler (Fd= -1)

    Gebe ich eine 2. CCSID an (wie im Beispielcode in dem Link):
    Flags = O_WRONLY + O_CREAT + O_APPEND + O_CCSID +O_TEXTDATA +
    O_TEXT_CREAT;
    Mode = S_IRWXU + S_IRWXG + S_IRWXO;
    Fd = Open(%Trim(txt_file):Flags:Mode:1252:1252);

    Bekomme ich einen Umwandlungsfehler mit dem Hinweis:
    RNF5407 20 1 Mehr Parameter im Prototypaufruf übergeben als zulässig.

    Im Beispiel werden ja auch die beiden Parameter mit übergeben:

    unsigned int file_ccsid = 819;
    unsigned int open_ccsid = 37;

    /************************************************** */
    /* First create the file with the CCSID 819, and */
    /* open it such that the data is converted */
    /* between the the open CCSID of 37 and the */
    /* file's CCSID of 819 when writing data to it. */
    /************************************************** */

    if ((fd=open(name,oflag1,mode,file_ccsid,open_ccsid)) < 0)

  10. #10
    Registriert seit
    Feb 2001
    Beiträge
    20.254
    Du musst natürlich einen eigenen Prototyp definieren, der 5 Parameter erlaubt.
    Die 2. CCSID muss dann auch eine DB-unterstützte CCSID wie 273, 1141, 1200 sein.
    Dienstleistungen? Die gibt es hier: http://www.fuerchau.de
    Das Excel-AddIn: https://www.ftsolutions.de/index.php/downloads
    BI? Da war doch noch was: http://www.ftsolutions.de

  11. #11
    Registriert seit
    Sep 2018
    Beiträge
    94
    habs ausprobiert!

    Hier der Code:

    D open PR 10I 0 extproc('open')
    D path * value options(*string)
    D oflag 10I 0 value
    D mode 10U 0 value options(*nopass)
    D codepage 10U 0 value options(*nopass)
    D codepage1 10U 0 value options(*nopass)


    ...

    Flags = O_WRONLY + O_CREAT + O_APPEND + O_CCSID;
    Mode = S_IRWXU + S_IRWXG + S_IRWXO;

    Fd = Open(%Trim(txt_file):O_CCSID+O_WRONLY+O_TEXTDATA+
    O_TEXT_CREAT:1252:273);

    Fd = -1 (leider!!)

    ich denke, mit der Variante

    Open => Close => Open => Write => Close

    kann ich gut leben!

  12. #12
    Registriert seit
    Feb 2001
    Beiträge
    20.254
    Diese Hinweise hätte ich nun glatt von Birgitta erwartet;-):
    https://www.ibm.com/support/knowledg...udfifsread.htm
    https://www.ibm.com/support/knowledg...ocifswrite.htm

    Schön, wer bereits V7R4 im Einsatz hat.
    Dienstleistungen? Die gibt es hier: http://www.fuerchau.de
    Das Excel-AddIn: https://www.ftsolutions.de/index.php/downloads
    BI? Da war doch noch was: http://www.ftsolutions.de

Similar Threads

  1. Programm aus QRPLOBJ wird dem echten Programm vorgezogen
    By dschroeder in forum NEWSboard Programmierung
    Antworten: 4
    Letzter Beitrag: 30-01-17, 13:36
  2. Antworten: 15
    Letzter Beitrag: 05-01-16, 15:42
  3. PDFs aus dem IFS ausdrucken - direkt von der IBMi
    By JoergHamacher in forum NEWSboard Programmierung
    Antworten: 8
    Letzter Beitrag: 28-11-13, 09:56
  4. iSeries Tools direkt aus dem Internet
    By Kilianski in forum NEWSboard Server Software
    Antworten: 0
    Letzter Beitrag: 08-08-02, 16:07
  5. Von AS/400 direkt in MS-SQL-Server schreiben
    By Michael@Paff.de in forum IBM i Hauptforum
    Antworten: 1
    Letzter Beitrag: 28-04-02, 08:42

Tags for this Thread

Berechtigungen

  • Neue Themen erstellen: Nein
  • Themen beantworten: Nein
  • You may not post attachments
  • You may not edit your posts
  •