我的 XML文件就像这样
<A_VERY_VERY_LONG_TITLE xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://tempuri.org/">
<DATA_LIST>
<DATA_LIST>
<ELEMENT_NO1 xmlns="">ABCDEFG_1</ELEMENT_NO1>
<ELEMENT_NO2 xmlns="">1234567_1</ELEMENT_NO2>
<ELEMENT_NO3 xmlns=""/>
</DATA_LIST>
<DATA_LIST>
<ELEMENT_NO1 xmlns="">ABCDEFG_2</ELEMENT_NO1>
<ELEMENT_NO2 xmlns="">1234567_2</ELEMENT_NO2>
<ELEMENT_NO3 xmlns="">A1B2C3D_2</ELEMENT_NO3>
</DATA_LIST>
<DATA_LIST>
<ELEMENT_NO1 xmlns="">ABCDEFG_3</ELEMENT_NO1>
<ELEMENT_NO2 xmlns="">1234567_3</ELEMENT_NO2>
<ELEMENT_NO3 xmlns="">A1B2C3D_3</ELEMENT_NO3>
</DATA_LIST>
</DATA_LIST>
<SOMETHING>SOME-VALUE</SOMETHING>
<SOMETHING_ELSE>SOME-OTHER-VALUE</SOMETHING_ELSE>
</A_VERY_VERY_LONG_TITLE>
我的代码示例是
DEFINE VARIABLE lOK AS LOGICAL NO-UNDO.
DEFINE TEMP-TABLE DATA_LIST NO-UNDO
FIELD ELEMENT_NO1 AS CHARACTER
FIELD ELEMENT_NO2 AS CHARACTER
FIELD ELEMENT_NO3 AS CHARACTER .
DEFINE DATASET DATA FOR DATA_LIST.
lOk = DATASET DATA:READ-XML("file", /* SourceType */
"C:\xmlFile.xml", /* File */
"append", /* ReadMode */
?, /* SchemaLocation */
?, /* OverrideDefaultMapping */
?, /* FieldTypeMapping */
?). /* VerifySchemaMode */
FOR EACH DATA_LIST:
DISPLAY DATA_LIST.ELEMENT_NO1 FORMAT "x(20)"
DATA_LIST.ELEMENT_NO2 FORMAT "x(20)"
DATA_LIST.ELEMENT_NO3 FORMAT "x(20)"
WITH WIDTH 120 .
END.
我可以成功访问DATA_LIST元素。但我无法获得数据“SOMETHING”和“SOMETHING_ELSE”。我也试图为这个值定义一个Temp-Table但它无法工作。 (我的屏幕空白了。)
感谢您的帮助。
答案 0 :(得分:4)
某些内容和其他内容超出了Data_List表的定义。试试这个:
DEFINE VARIABLE lOK AS LOGICAL NO-UNDO.
DEFINE TEMP-TABLE DATA_LIST NO-UNDO
FIELD ELEMENT_NO1 AS CHARACTER
FIELD ELEMENT_NO2 AS CHARACTER
FIELD ELEMENT_NO3 AS CHARACTER .
Define Temp-Table A_VERY_VERY_LONG_TITLE no-undo
field SOMETHING as character
field SOMETHING_ELSE as character.
DEFINE DATASET DATA FOR DATA_LIST, A_VERY_VERY_LONG_TITLE.
lOk = DATASET DATA:READ-XML("file", /* SourceType */
"C:\xmlFile.xml", /* File */
"append", /* ReadMode */
?, /* SchemaLocation */
?, /* OverrideDefaultMapping */
?, /* FieldTypeMapping */
?). /* VerifySchemaMode */
FOR EACH DATA_LIST:
DISPLAY DATA_LIST.ELEMENT_NO1 FORMAT "x(20)"
DATA_LIST.ELEMENT_NO2 FORMAT "x(20)"
DATA_LIST.ELEMENT_NO3 FORMAT "x(20)"
WITH WIDTH 120 .
END.
For EACH A_VERY_VERY_LONG_TITLE:
DISPLAY A_VERY_VERY_LONG_TITLE.SOMETHING format "x(40)"
A_VERY_VERY_LONG_TITLE.SOMETHING_ELSE format "x(40)"
WITH WIDTH 220.
END.
它对我有用:)