[NEWSboard IBMi Forum]

Hybrid View

  1. #1
    Registriert seit
    Feb 2001
    Beiträge
    20.808
    Nein.
    Ich habe mich mit diesem API auch noch nicht beschäftigt.
    Lieber ist mir das dazu passende OPM-API:
    Convert a Graphic Character String (CDRCVRT, QTQCVRT) API

    Das ist einfacher und funktioniert auch genauso schnell.
    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

  2. #2
    Registriert seit
    Nov 2012
    Beiträge
    51
    Toschie, der Code funktioniert, Du hast nur vergessen, die DS fromCCSID und toCCSID richtig zu initialisieren, sprich, die "Inz(*LIKEDS)"
    hast Du sowohl bei fromCCSID und toCCSID vergessen. Wenn Du die beiden einbaust, kriegst Du kein -1 und er übersetzt Dein ABCDEFG auch.

  3. #3
    Registriert seit
    Jan 2005
    Beiträge
    90
    Zitat Zitat von Anton Gombkötö Beitrag anzeigen
    Toschie, der Code funktioniert, Du hast nur vergessen, die DS fromCCSID und toCCSID richtig zu initialisieren, sprich, die "Inz(*LIKEDS)"
    hast Du sowohl bei fromCCSID und toCCSID vergessen. Wenn Du die beiden einbaust, kriegst Du kein -1 und er übersetzt Dein ABCDEFG auch.
    Das mit dem -1 ist weg!
    Vielen Dank dafür.
    Allerdings scheint mir die Konvertierung nicht zu klappen.
    Gebe ich zum Beispiel anstatt ABCDEF die Werte
    ABCÜäFG aus, erhalte ich sowohl mit und ohne iConv die Ausgabe ABCš„FG

    @Fuerchau: Hast du ein gutes/kleines Sample für
    Convert a Graphic Character String (CDRCVRT, QTQCVRT) API

    Würde mir das Parallal dann auch noch gerne ansehen.
    Vielen Dank allen beteiligten und ein schönes Wochenende!

  4. #4
    Registriert seit
    Feb 2001
    Beiträge
    20.808
    Nein, ein Beispiel steht mir im Moment leider nicht zur Verfügung.

    Wie kontrollierst du denn die Ausgabe nach iConv() ?

    Ein 'Ü' in 1252 entspricht x'DC'.
    Wenn du im Debugger den Inhalt Hex vergleichst, weißt du dass die Konvertierung funktioniert.
    Prüfst du über das Ziel-System, ist ggf. 1252 nicht korrekt.

    Aber nochmal:
    Stelle den obigen Header ".... Encoding="ISO-8859-1" ..." ein, damit ein XMLReader die daten korrekt interpretiert.

    Durch dein BOM erwartet der Reader ggf. UTF-8 und dann müsstest du halt in 1208 konvertieren.
    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

  5. #5
    Registriert seit
    Jan 2005
    Beiträge
    90
    @Fuechau:
    Danke und ich habe dem Kunden bereits eine Datei mit iso geschickt zur Validierung.
    Diese wird aktuell noch geprüft.
    Da ich aber gerne wissen würde ob der Befehl grundsätzlich richtig implementiert wurde (für die Zukunft), hake ich halt nochmal nach.
    Also vor dem Durchlauf von
    PHP-Code:
    /free
    fromCCSID
    .CCSID 0;
    toCCSID.CCSID 1208;
    hConv = *ALLX'00';
    hConv QtqIconvOpen(toCCSID:fromCCSID);
    /
    end-free
     
     
    C    eval output = *Blanks
    C    
    eval nInLen = %len(%TrimR(mydata))
    C    eval nOutLen = %size(mydata)
    C    eval pData = %addr(myData)
    C    eval ppData = %addr(output)
    C    callp iconv(hConv pData : %addr(nInLen):
    C    ppData:%addr(nOutLen)) 
    Lautet in RDI der Hexwert von (MyData)
    ABCÜäFG -> C1C2C35AC0C6C7404040

    Und nach dem Durchlauf:
    (MyData)
    C1C2C35AC0C6C7404040

    Also unverändert.
    Der Wert in OUTPUT ist Blank.
    Ich hab da bestimmt noch n dummen Fehler -.-

  6. #6
    Registriert seit
    Feb 2001
    Beiträge
    20.808
    Die fromCCSID.CCSID sollte nicht 0 sein.
    Da 0 ggf. als "JOB-CCSID" interpretiert wird, sollte der Job nicht auf *HEX (65535) stehen.
    Wenn deine DB die CCSID 273 hat bzw. deine Terminals 1141 haben, nimm als fromCCSID eben 273/1141.
    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

  7. #7
    Registriert seit
    Jan 2005
    Beiträge
    90
    Zitat Zitat von Fuerchau Beitrag anzeigen
    Die fromCCSID.CCSID sollte nicht 0 sein.
    Da 0 ggf. als "JOB-CCSID" interpretiert wird, sollte der Job nicht auf *HEX (65535) stehen.
    Wenn deine DB die CCSID 273 hat bzw. deine Terminals 1141 haben, nimm als fromCCSID eben 273/1141.
    Habe ich alles versucht.
    Bleibt alles unverändert.
    Ich habe gestern Abend noch ein anderes Sample gefunden:

    Code:
    * Quick & Dirty iconv() Demo
    *
    *
    H DFTACTGRP(*NO) ACTGRP(*NEW)
    H BNDDIR('QC2LE')
    d iconv_t DSbased(prototype_only)
    d return_value10I 0
    d cd 10I 0dim(12)
    d from DS
    d from_CCSID 10I 0
    d from_ConvAlt 10I 0inz(0)
    d from_SubsAlt 10I 0inz(0)
    d from_ShiftAlt10I 0inz(1)
    d from_InpLenOp10I 0inz(0)
    d from_ErrorOpt10I 0inz(1)
    D from_Reserved8Ainz(*ALLx'00')
    d to DS
    d to_CCSID 10I 0
    d to_ConvAlt 10I 0inz(0)
    d to_SubsAlt 10I 0inz(0)
    d to_ShiftAlt 10I 0inz(1)
    d to_InpLenOp 10I 0inz(0)
    d to_ErrorOpt 10I 0inz(1)
    D to_Reserved 8Ainz(*ALLx'00')
    d QtqIconvOpen PRextproc('QtqIconvOpen')
    dlike(iconv_t)
    d tocode like(to) const
    d fromcode like(from) const
    d iconv PR10U 0extproc('iconv')
    d cd like(iconv_t) value
    d inbuf *
    d inbytesleft 10U 0
    d outbuf *
    d outbytesleft10U 0
    D iconv_close PR10I 0extproc('iconv_close')
    D cd like(iconv_t) value
    *
    * MI function to get a hex dump of data in memory
    * (target will be twice the size of the source)
    *
    D HexDump PRExtProc('cvthc')
    D target 32767Aoptions(*varsize)
    D src_bits 32767Aoptions(*varsize) const
    D length 10I 0value
    D ic dslikeds(iconv_t)
    D Data s 12Avarying
    D p_Data s *
    D DataLen s 10U 0
    D HexData s 24A
    *
    * 1252 = MS Windows, US ASCII
    * 0 = special value meaning "current job's CCSID"
    *
    ceval to_CCSID = 1208
    ceval from_CCSID = 273
     
    *
    * initialize iconv() API
    *
    ceval ic = QtqIconvOpen(to: from)
    cif ic.return_value = -1
    ** ... FIXME: handle error ...
    cendif
     
    *
    * Convert "hello world" to Windows ASCII
    *
    *
    ceval Data = 'ABCÜäFG'
    ceval p_Data = %addr(Data) + 2
    ceval DataLen = %len(Data)
    cif iconv(ic: p_Data: DataLen:
    cp_Data: DataLen) = -1
    ** ... FIXME: handle error ...
    cendif
    *
    * Create hex dump to test conversion
    *
    ccallp HexDump( HexData
    c: Data
    c: %size(HexData))
    cdsply HexData
     
    *
    * call iconv_close() to free up resources when done
    *
    ccallp iconv_close(ic)
    ceval *inlr = *on
    
    Jedoch wandelt mir dieses Ding alles um.
    Das Ergebnis von:
    'ABCÜäFG' ->
    0007C1C2C35AC0C6C70000000000
    ist
    â{CæCw -> 0007414243C39CC3A60000000000

  8. #8
    Registriert seit
    Feb 2001
    Beiträge
    20.808
    Das API unterstützt keine varying-Felder!
    Die Länge der Ein-/Ausgabe wird ja in separaten Feldern übergeben.
    Verwende bitte Fixed-Charfelder!

    Du kannst es ja am Ergebnis sehen, dass nur die ersten 7 Stellen umgewandelt wurden.
    Die x'0007' ist die Längeninformation des Varying-Feldes.
    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
    Jan 2005
    Beiträge
    90
    Zitat Zitat von Fuerchau Beitrag anzeigen
    Das API unterstützt keine varying-Felder!
    Die Länge der Ein-/Ausgabe wird ja in separaten Feldern übergeben.
    Verwende bitte Fixed-Charfelder!

    Du kannst es ja am Ergebnis sehen, dass nur die ersten 7 Stellen umgewandelt wurden.
    Die x'0007' ist die Längeninformation des Varying-Feldes.
    Ok Danke.
    Bekomme als Ergebnis jetzt:
    AB{}Uãå ->
    C1C243DCE4464720....

    Ich habe das Feld Data jetzt mit 200A definiert.

  10. #10
    Registriert seit
    Nov 2012
    Beiträge
    51

    Na dann passt ja alles.

    @Toschie: Aus meiner Sicht solltest Du nun eigentlich glücklich sein.
    Was meinst mit aber mit "jedoch" und "alles"?
    So soll es doch sein; Du schreibst das ja nun sicherlich in eine *USERASCII Spool-Datei.

    @Fuerchau: das macht er ja schön, 2 Bytes zum Pointer dazugerechnet, damit er am Datenteil steht, und die Länge mit %LEN richtig initialisiert.
    Noch schöner, sozusagen der Telemark, wäre nur noch die Initialisierung des Pointers mit
    PHP-Code:
    pData = %ADDR(Data:*DATA); 

  11. #11
    Registriert seit
    Feb 2001
    Beiträge
    20.808
    Wenn das Zielergebnis aber länger als die aktuelle Längenangabe ist, kommt man leider an die Zeichen hinter der Länge nur über eine Fixed-Char-Variable mit Based(Pointer) dran, da der normale Zugriff immer die Länge berücksichtigt. Bei CCSID 13488 wird das am deutlichsten.

    Das "Ergebnis" ist allerdings immer noch EBCDIC und nicht UTF-8!
    Also irgendwas stimmt da immer noch nicht mit der API-Versorgung.
    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

  12. #12
    Registriert seit
    Nov 2012
    Beiträge
    51

    Ich mach das aber so.

    Und rechne mir die Länge aus (zur Verfügung gestellter Speicherplatz - von iconv übrig gelassener Speicherplatz). Das setze ich dann mit %LEN(variable) = ermittelter Wert.

    Ja, das hatte er schon mal besser. :-)

Similar Threads

  1. XML: <?XML version=... ?> und <!DOCTYPE ... >
    By VolkerGrebner in forum NEWSboard Programmierung
    Antworten: 2
    Letzter Beitrag: 16-02-07, 15:38
  2. Webservices, SOAP, XML und Labeldruck
    By vige1000 in forum NEWSboard Linux
    Antworten: 4
    Letzter Beitrag: 21-12-06, 12:56
  3. MCH3402 + Spool
    By Robi in forum IBM i Hauptforum
    Antworten: 2
    Letzter Beitrag: 14-12-06, 12:12
  4. XML zu einem Port Senden
    By Weki in forum IBM i Hauptforum
    Antworten: 4
    Letzter Beitrag: 11-09-06, 14:31
  5. Spool -> PDF benötigte Lizenzprogramme
    By cseitz in forum IBM i Hauptforum
    Antworten: 0
    Letzter Beitrag: 20-06-06, 15:40

Berechtigungen

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