新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 本版讨论DOM, SAX, XPath等。
    [返回] 中文XML论坛 - 专业的XML技术讨论区XML.ORG.CN讨论区 - XML技术『 DOM/SAX/XPath 』 → 关于子节点的问题[求助] 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 2484 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: 关于子节点的问题[求助] 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     luckerdzr 美女呀,离线,快来找我吧!
      
      
      等级:大一新生
      文章:10
      积分:90
      门派:XML.ORG.CN
      注册:2005/4/21

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给luckerdzr发送一个短消息 把luckerdzr加入好友 查看luckerdzr的个人资料 搜索luckerdzr在『 DOM/SAX/XPath 』的所有贴子 引用回复这个贴子 回复这个贴子 查看luckerdzr的博客楼主
    发贴心情 关于子节点的问题[求助]

    文件domtree.java
    import java.io.*;
    import java.util.*;
    import org.w3c.dom.*;
    import javax.xml.parsers.*;
    public class domtree extends Object
    {
        public static void main(String args[ ])
        {
             DocumentBuilderFactory factory;
             DocumentBuilder docBuilder;
             Document doc;
             Element root;
             String name;
             
             try
             {
                factory=DocumentBuilderFactory.newInstance();
                factory.setValidating(false);
                docBuilder=factory.newDocumentBuilder();
                doc=docBuilder.parse(new FileInputStream(args[0]));
                root=doc.getDocumentElement();
                //System.out.println(root); //print the all xml content
                name=root.getNodeName();
                System.out.println(name);
                getChildren(root);
                }
                
             catch (Exception exp)
             {
                exp.printStackTrace();
                }
            }         
         public static void getChildren(Element elem)
         {
          Node child;
          NodeList children;
             int i,Max;
             String elemName;
                 
          children=elem.getChildNodes();
             Max=children.getLength();
             System.out.println(Max);
          //child=elem.getFirstChild();
             for (i=0;i<Max;i++)
             {
              child=children.item(i);
              elemName=child.getNodeName();
                             System.out.println(elemName);
              }
            }
      }

    文件 library.xml
    <?xml version="1.0" encoding="GB2312"?>
    <ns:library xmlns:ns="http://www.javaserverprogramming.com/library">
    <book ISBN="12">
    <title>Visual C++入门与精通</title>
    <author country="China">VC工作室</author>
    <press>清华大学出版社</press>
    <price unit="RMB">45</price>
    <copies>3</copies>
    </book>
    <book ISBN="34">
    <title>Thinking in Java</title>
    <author country="USA">Bruce Eckel</author>
    <press>机械工业出版社</press>
    <price unit="RMB">60</price>
    <copies>10</copies>
    </book>
    </ns:library>

    结果
    ns:library
    5
    #text
    book
    #text
    book
    #text

    根节点居然有五个子节点,请问这个根节点是怎么看的?
    怎么会有三个Text型的节点????


       收藏   分享  
    顶(0)
      




    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/4/27 23:38:00
     
     binaryluo 帅哥哟,离线,有人找我吗?
      
      
      威望:6
      等级:研二(Pi-Calculus看得一头雾水)(版主)
      文章:679
      积分:5543
      门派:IEEE.ORG.CN
      注册:2005/2/19

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给binaryluo发送一个短消息 把binaryluo加入好友 查看binaryluo的个人资料 搜索binaryluo在『 DOM/SAX/XPath 』的所有贴子 引用回复这个贴子 回复这个贴子 查看binaryluo的博客2
    发贴心情 
    举个例子:
    XML文件:
    <?xml version="1.0" encoding="GB2312"?>
      <library>
        <book>book1</book>
        <book>book2</book>
        <book>book3</book>
      </library>
    </xml>
    在该文件中,表面上看library有3个孩子,这种理解是错误的。library实际上有7个孩子:
    另外四个是#text类型的,在这个上面的例子里他们的值为空,所以看上去好像只有3个孩子。
    再看下面这个例子:
    <?xml version="1.0" encoding="GB2312"?>
      <library>aaaaa
        <book>book1</book>bbbbb
        <book>book2</book>cccccc
        <book>book3</book>ddddd
      </library>
    </xml>
    这个例子中就可以明显的看出有7个孩子:
    第一个孩子是#text类型的,他的值是aaaaa
    第二个孩子是#Element类型的,该孩子(第二个孩子)又有一个孩子是#text类型的,他的值是book1
    第三个孩子是#text类型的,他的值是bbbbb
    .....
    剩下的四个孩子依此类推。
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/4/28 13:21:00
     
     luckerdzr 美女呀,离线,快来找我吧!
      
      
      等级:大一新生
      文章:10
      积分:90
      门派:XML.ORG.CN
      注册:2005/4/21

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给luckerdzr发送一个短消息 把luckerdzr加入好友 查看luckerdzr的个人资料 搜索luckerdzr在『 DOM/SAX/XPath 』的所有贴子 引用回复这个贴子 回复这个贴子 查看luckerdzr的博客3
    发贴心情 
    谢谢!
    但是我现在只想标记有内容的Text区域。
    怎么区分是否有内容呢?


    [此贴子已经被作者于2005-5-8 17:33:55编辑过]
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/5/8 11:44:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 DOM/SAX/XPath 』的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2025/7/17 13:13:31

    本主题贴数3,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    50.781ms