老R3(非Unicode系統),發現讀取出來的數據中有編碼爲0的字符,存文件後發現串行,因此須要先替換
DATA: str TYPE string.
*str = zacct_12-txt+47.
str = '南京人力資源部'.
"C4CFBEA9C8CBC1A6D7CAD4B4B2BF
DATA:c(17).
FIELD-SYMBOLS: <c> TYPE x .
ASSIGN c TO <c> CASTING.
<c> = '00C4CFBEA9C8CB00C1A6D7CAD4B4B2BF00'."在
南京人力資源部 前中後加上了空字符00,方便測試
WRITE:/ c,<c>.
str = c.
PERFORM replace_null USING str.
*&---------------------------------------------------------------------*
*& Form replace_null
*&---------------------------------------------------------------------*
* text R3系統中替換字符串中的空字符(編碼爲0的)
*----------------------------------------------------------------------*
* -->P_STR text
*----------------------------------------------------------------------*
FORM replace_null USING p_str TYPE string.
******************************編
DATA: xstr TYPE xstring.
DATA: l_codepage(4) TYPE n .
DATA: l_encoding(20).
CALL FUNCTION 'SCP_CODEPAGE_BY_EXTERNAL_NAME'
EXPORTING
external_name = 'UTF-16BE'"無論中文仍是英文,先統一編碼,都轉成兩字節的
IMPORTING
sap_codepage = l_codepage.
l_encoding = l_codepage.
DATA: convout TYPE REF TO cl_abap_conv_out_ce.
convout = cl_abap_conv_out_ce=>create( encoding = l_encoding ).
convout->write( data = p_str ).
xstr = convout->get_buffer( ).
******************************替
DATA:truc_str TYPE string,
str_len TYPE i.
truc_str = xstr.
str_len = STRLEN( truc_str ).
str_len = str_len / 4 .
DATA: cnt TYPE i.
DATA: c4(4) .
DATA: x2(2) TYPE x.
DATA: i TYPE i.
DATA: xstr2 TYPE xstring.
DATA: off_index TYPE i.
DO str_len TIMES.
off_index = cnt * 4.
c4 = truc_str+off_index(4).
x2 = c4.
i = x2.
IF i = 0."若是發現是空字符,使用空格替換
x2 = '0020'.
CONCATENATE xstr2 x2 INTO xstr2 IN BYTE MODE.
ELSE.
CONCATENATE xstr2 x2 INTO xstr2 IN BYTE MODE.
ENDIF.
WRITE: / c4,x2,i,xstr2.
cnt = cnt + 1.
ENDDO.
******************************解
DATA: convin TYPE REF TO cl_abap_conv_in_ce.
convin = cl_abap_conv_in_ce=>create( encoding = l_encoding input = xstr2 ).
DATA: str TYPE string.
CALL METHOD convin->read
IMPORTING
data = p_str.
WRITE: / p_str.
ENDFORM. "replace_null