我正在使用一个简单的xml文件。

<COMPANY>
    <EMPLOYEES>
            <EMPLOYEE>
                <NAME>BOB</NAME>
                <EMPID>51211</EMPID>
                <SEX>M</SEX>
                <DOB>10-1-1982</DOB>
                <DOJ>12-7-2001</DOJ>
        </EMPLOYEE>
    </EMPLOYEES>
</COMPANY>


相同的xml booster元定义文件如下

    <SYSTEM NAME="testmeta" >
    <CCONFIG MAXLEN="100"
       ARRAYSIZE="5"
       FLATMODE="TRUE"/>
    <ELEMENT NAME="COMPANY" TAG="COMPANY" MAIN="TRUE" >
            <FIELDS>
                    <FIELD NAME="EMPLOYEES" REFTYPE="EMPLOYEE" MODE="DEFAULT" />
            </FIELDS>
            <FORMULA>
                    <ENCLOSED NAME="EMPLOYEES" >
                            <META NAME="COMMENT" >Target field is EMPLOYEES</META>
                            <REPEAT TARGET="EMPLOYEES" ATLEASTONE="TRUE" >
                                    <ELEMENTREF NAME="EMPLOYEE" />
                            </REPEAT>
                    </ENCLOSED>
            </FORMULA>
    </ELEMENT>
    <ELEMENT NAME="EMPLOYEE" TAG="EMPLOYEE" >
            <FIELDS>
                    <FIELD NAME="NAME" TYPE="STRING" />
                    <FIELD NAME="EMPID" TYPE="INTEGER" />
                    <FIELD NAME="SEX" TYPE="STRING" />
                    <FIELD NAME="DOB" TYPE="STRING" />
                    <FIELD NAME="DOJ" TYPE="STRING" />
            </FIELDS>
            <FORMULA>
                    <CONCAT>
                            <ENCLOSED NAME="NAME" >
                                    <META NAME="COMMENT" >Target field is NAME</META>
                                    <PCDATA TARGET="NAME" />
                            </ENCLOSED>
                            <ENCLOSED NAME="EMPID" >
                                    <META NAME="COMMENT" >Target field is EMPID</META>
                                    <PCDATA TARGET="EMPID" />
                            </ENCLOSED>
                            <ENCLOSED NAME="SEX" >
                                    <META NAME="COMMENT" >Target field is SEX</META>
                                    <PCDATA TARGET="SEX" />
                            </ENCLOSED>
                            <ENCLOSED NAME="DOB" >
                                    <META NAME="COMMENT" >Target field is DOB</META>
                                    <PCDATA TARGET="DOB" />
                            </ENCLOSED>
                            <ENCLOSED NAME="DOJ" >
                                    <META NAME="COMMENT" >Target field is DOJ</META>
                                    <PCDATA TARGET="DOJ" />
                            </ENCLOSED>
                    </CONCAT>
            </FORMULA>
    </ELEMENT>
</SYSTEM>


使用以下命令使用xmlbooster lite为该文件生成.c和.h文件

xmlblit.exe -C testmeta.xmlb


现在在我的应用程序中,在main函数中,我调用accept_COMPANY函数并传递S_XMLB_CONTEXT上下文对象。功能成功,但是当我使用以下命令打印每个员工值时

    printf("%s, %d, %s, %s, %s", En->aNAME,
    En->aEMPID,
    En->aSEX,
    En->aDOB,
    En->aDOJ);
    printf("\n");


我正在打印垃圾字符,即使对于整数aEMPID值也是如此。

我正在使用Visual Studio 2010编译和运行C程序。

尝试了Unicode和MultiByte项目,但没有获得正确值的运气。

我正在输出为

    UOB, 78, M, j0-1-1982, 1t-7-2001


调试生成的.c文件后,发现生成器正在为PCDATA类型字段设置不需要的值。例如从XML检索名称后的NAME字段,代码具有以下语句

/* Regexp */
if (strlen(obj->aNAME) > 0)
    (obj->aNAME)[0] = 'U';


有人遇到过类似情况吗?

最佳答案

写给xmlbooster的支持得到了以下答复。


  XMLBooster Lite仅支持Java; C仅用于评估目的,因为您会在示例程序和生成的代码中发现值被扰乱。您需要购买XMLBooster Pro才能在C语言中生成生产级解析器。


得到了答案,希望这也对正在尝试的其他人有所帮助。

关于c - 解析后在C结构中获取垃圾字符,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/13875176/

10-11 15:34