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

    >> 本版讨论XSL,XSLT,XSL-FO,CSS等技术
    [返回] 中文XML论坛 - 专业的XML技术讨论区XML.ORG.CN讨论区 - XML技术『 XSL/XSLT/XSL-FO/CSS 』 → [求助]用Excel生成的xml怎么转换 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 4780 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: [求助]用Excel生成的xml怎么转换 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     hyl_fr 帅哥哟,离线,有人找我吗?
      
      
      等级:大二(研究汇编)
      文章:40
      积分:239
      门派:XML.ORG.CN
      注册:2004/12/31

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给hyl_fr发送一个短消息 把hyl_fr加入好友 查看hyl_fr的个人资料 搜索hyl_fr在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 引用回复这个贴子 回复这个贴子 查看hyl_fr的博客楼主
    发贴心情 [求助]用Excel生成的xml怎么转换

    我把Excel文件另存为xml文件如下示,不知道用xsl转换应该怎么写,大家帮帮忙
    数据是中间的row之间,每个row之间是一行所要显示的

    <?xml version="1.0" encoding="GB2312" ?>
    <?mso-application progid="Excel.Sheet"?>
    <Workbook xmlns="urn:schemas-microsoft-com:office:spreadsheet"
    xmlns:o="urn:schemas-microsoft-com:office:office"
    xmlns:x="urn:schemas-microsoft-com:office:excel"
    xmlns:ss="urn:schemas-microsoft-com:office:spreadsheet"
    xmlns:html="http://www.w3.org/TR/REC-html40">
    <DocumentProperties xmlns="urn:schemas-microsoft-com:office:office">
      <LastAuthor>MC SYSTEM</LastAuthor>
      <Created>2005-01-18T02:08:49Z</Created>
      <Version>11.5606</Version>
    </DocumentProperties>
    <ExcelWorkbook xmlns="urn:schemas-microsoft-com:office:excel">
      <WindowHeight>9150</WindowHeight>
      <WindowWidth>14940</WindowWidth>
      <WindowTopX>360</WindowTopX>
      <WindowTopY>270</WindowTopY>
      <AcceptLabelsInFormulas/>
      <ProtectStructure>False</ProtectStructure>
      <ProtectWindows>False</ProtectWindows>
    </ExcelWorkbook>
    <Styles>
      <Style ss:ID="Default" ss:Name="Normal">
       <Alignment ss:Vertical="Center"/>
       <Borders/>
       <Font ss:FontName="宋体" x:CharSet="134" ss:Size="12"/>
       <Interior/>
       <NumberFormat/>
       <Protection/>
      </Style>
    </Styles>
    <Worksheet ss:Name="Sheet1">
      <Table ss:ExpandedColumnCount="9" ss:ExpandedRowCount="287" x:FullColumns="1"
       x:FullRows="1" ss:DefaultColumnWidth="54" ss:DefaultRowHeight="14.25">
       <Column ss:AutoFitWidth="0" ss:Width="90"/>
       <Column ss:AutoFitWidth="0" ss:Width="60"/>
       <Column ss:AutoFitWidth="0" ss:Width="180"/>
       <Column ss:AutoFitWidth="0" ss:Width="90" ss:Span="2"/>
       <Column ss:Index="7" ss:AutoFitWidth="0" ss:Width="60"/>
       <Column ss:AutoFitWidth="0" ss:Width="90"/>
       <Column ss:AutoFitWidth="0" ss:Width="180"/>
       <Row>
        <Cell><Data ss:Type="String">351982086556</Data></Cell>
        <Cell><Data ss:Type="String">序号</Data></Cell>
        <Cell><Data ss:Type="String">42.0.45.220</Data></Cell>
        <Cell><Data ss:Type="String">2004-01-01</Data></Cell>
        <Cell><Data ss:Type="String">6091145</Data></Cell>
        <Cell><Data ss:Type="String">test</Data></Cell>
       </Row>
       <Row>
        <Cell><Data ss:Type="String">351982086154</Data></Cell>
        <Cell><Data ss:Type="String">序号</Data></Cell>
        <Cell><Data ss:Type="String">42.0.54.154</Data></Cell>
        <Cell><Data ss:Type="String">2004-01-01</Data></Cell>
        <Cell><Data ss:Type="String">2288681</Data></Cell>
        <Cell><Data ss:Type="String">test</Data></Cell>
       </Row>
       <Row>
        <Cell><Data ss:Type="String">351982086754</Data></Cell>
        <Cell><Data ss:Type="String">序号</Data></Cell>
        <Cell><Data ss:Type="String">42.0.44.60</Data></Cell>
        <Cell><Data ss:Type="String">2004-01-01</Data></Cell>
        <Cell><Data ss:Type="String">6892618</Data></Cell>
        <Cell><Data ss:Type="String">test</Data></Cell>
       </Row>
      </Table>
      <WorksheetOptions xmlns="urn:schemas-microsoft-com:office:excel">
       <PageSetup>
        <Layout x:Orientation="Landscape"/>
       </PageSetup>
       <Print>
        <ValidPrinterInfo/>
        <PaperSizeIndex>0</PaperSizeIndex>
        <Scale>285</Scale>
        <VerticalResolution>0</VerticalResolution>
       </Print>
       <Selected/>
       <ProtectObjects>False</ProtectObjects>
       <ProtectScenarios>False</ProtectScenarios>
      </WorksheetOptions>
    </Worksheet>
    <Worksheet ss:Name="Sheet2">
      <Table ss:ExpandedColumnCount="0" ss:ExpandedRowCount="0" x:FullColumns="1"
       x:FullRows="1" ss:DefaultColumnWidth="54" ss:DefaultRowHeight="14.25"/>
      <WorksheetOptions xmlns="urn:schemas-microsoft-com:office:excel">
       <PageSetup>
        <Layout x:Orientation="Landscape"/>
       </PageSetup>
       <Print>
        <ValidPrinterInfo/>
        <PaperSizeIndex>0</PaperSizeIndex>
        <Scale>285</Scale>
        <VerticalResolution>0</VerticalResolution>
       </Print>
       <ProtectObjects>False</ProtectObjects>
       <ProtectScenarios>False</ProtectScenarios>
      </WorksheetOptions>
    </Worksheet>
    <Worksheet ss:Name="Sheet3">
      <Table ss:ExpandedColumnCount="0" ss:ExpandedRowCount="0" x:FullColumns="1"
       x:FullRows="1" ss:DefaultColumnWidth="54" ss:DefaultRowHeight="14.25"/>
      <WorksheetOptions xmlns="urn:schemas-microsoft-com:office:excel">
       <PageSetup>
        <Layout x:Orientation="Landscape"/>
       </PageSetup>
       <Print>
        <ValidPrinterInfo/>
        <PaperSizeIndex>0</PaperSizeIndex>
        <Scale>285</Scale>
        <VerticalResolution>0</VerticalResolution>
       </Print>
       <ProtectObjects>False</ProtectObjects>
       <ProtectScenarios>False</ProtectScenarios>
      </WorksheetOptions>
    </Worksheet>
    </Workbook>

    [此贴子已经被作者于2005-1-18 11:37:35编辑过]

       收藏   分享  
    顶(0)
      




    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/1/18 10:46:00
     
     doubleG 帅哥哟,离线,有人找我吗?
      
      
      威望:7
      等级:大三(面向对象是个好东东!)
      文章:591
      积分:4119
      门派:XML.ORG.CN
      注册:2004/5/27

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给doubleG发送一个短消息 把doubleG加入好友 查看doubleG的个人资料 搜索doubleG在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 引用回复这个贴子 回复这个贴子 查看doubleG的博客2
    发贴心情 
    你是要还原吗?那可不会,好难呢 呵呵 如果解析话要记住把XML中声明的名称空间在XSL中也要声明一下就好了,使用时加上prefix就行。以前有过这样的帖子,本来想给个链接,翻不到了。不好意思,呵呵
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/1/18 14:19:00
     
     hyl_fr 帅哥哟,离线,有人找我吗?
      
      
      等级:大二(研究汇编)
      文章:40
      积分:239
      门派:XML.ORG.CN
      注册:2004/12/31

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给hyl_fr发送一个短消息 把hyl_fr加入好友 查看hyl_fr的个人资料 搜索hyl_fr在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 引用回复这个贴子 回复这个贴子 查看hyl_fr的博客3
    发贴心情 
    简单一些说是这样的,我用Excel生成一个xml文件,它的格式有些特殊,在转换的时候出现了问题,就像下面的xml文件的数据,转换只显示第一个Cell的数据,我不知道怎么样把数据都取出来

    <?xml version="1.0" encoding="GB2312" ?>
    <?xml:stylesheet type="text/xsl" href="pfyDevMessage1106012693493.xsl"?>
    <root>
       <Row>
        <Cell><Data Type="String">351982086556</Data></Cell>
        <Cell><Data Type="String">序号</Data></Cell>
        <Cell><Data Type="String">42.0.45.220</Data></Cell>
        <Cell><Data Type="String">2004-01-01</Data></Cell>
        <Cell><Data Type="String">6091145</Data></Cell>
        <Cell><Data Type="String">test</Data></Cell>
       </Row>
       <Row>
        <Cell><Data Type="String">351982086154</Data></Cell>
        <Cell><Data Type="String">序号</Data></Cell>
        <Cell><Data Type="String">42.0.54.154</Data></Cell>
        <Cell><Data Type="String">2004-01-01</Data></Cell>
        <Cell><Data Type="String">2288681</Data></Cell>
        <Cell><Data Type="String">test</Data></Cell>
       </Row>
       <Row>
        <Cell><Data Type="String">351982086754</Data></Cell>
        <Cell><Data Type="String">序号</Data></Cell>
        <Cell><Data Type="String">42.0.44.60</Data></Cell>
        <Cell><Data Type="String">2004-01-01</Data></Cell>
        <Cell><Data Type="String">6892618</Data></Cell>
        <Cell><Data Type="String">test</Data></Cell>
       </Row>
       </root>
    我的xsl:
    <?xml version="1.0" encoding="gb2312"?>
    <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
    <xsl:template match="/root">
    <html>
    <head>
    <TITLE>测试</TITLE>
    </head>
    <body>
    <xsl:for-each select="Row">
    <tr>
    <td noWrap="true" align="center"><xsl:value-of select="Cell"/></td>
    <br/>
    </tr>
    </xsl:for-each>
    </body>
    </html>
    </xsl:template>
    </xsl:stylesheet>

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/1/18 14:40:00
     
     hyl_fr 帅哥哟,离线,有人找我吗?
      
      
      等级:大二(研究汇编)
      文章:40
      积分:239
      门派:XML.ORG.CN
      注册:2004/12/31

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给hyl_fr发送一个短消息 把hyl_fr加入好友 查看hyl_fr的个人资料 搜索hyl_fr在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 引用回复这个贴子 回复这个贴子 查看hyl_fr的博客4
    发贴心情 
    上面的这个xml是可以正确输出的,只需在<xsl:for-each select="Row"><tr>后面加上
    <xsl:for-each select="Cell">然后把<td noWrap="true" align="center"><xsl:value-of select="Cell"/>里的Cell改为Data即可,但是最上面的那个xml由于有很多垃圾,就不会正确输出了,大家帮我解决一下吧
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/1/18 15:47:00
     
     doubleG 帅哥哟,离线,有人找我吗?
      
      
      威望:7
      等级:大三(面向对象是个好东东!)
      文章:591
      积分:4119
      门派:XML.ORG.CN
      注册:2004/5/27

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给doubleG发送一个短消息 把doubleG加入好友 查看doubleG的个人资料 搜索doubleG在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 引用回复这个贴子 回复这个贴子 查看doubleG的博客5
    发贴心情 
    那些可不是垃圾呢,呵呵 是一些必要但是你又不需要的东西,其实只要xsl写好了,还是很容易的。这几天在测试环境下没办法用xmlspy,测试结束后才能写个例子,不好意思。
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/1/18 16:24:00
     
     hyl_fr 帅哥哟,离线,有人找我吗?
      
      
      等级:大二(研究汇编)
      文章:40
      积分:239
      门派:XML.ORG.CN
      注册:2004/12/31

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给hyl_fr发送一个短消息 把hyl_fr加入好友 查看hyl_fr的个人资料 搜索hyl_fr在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 引用回复这个贴子 回复这个贴子 查看hyl_fr的博客6
    发贴心情 
    好,敬候你的例子,谢
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/1/18 16:39:00
     
     LULU3000 帅哥哟,离线,有人找我吗?
      
      
      等级:大一新生
      文章:0
      积分:58
      门派:XML.ORG.CN
      注册:2004/11/14

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给LULU3000发送一个短消息 把LULU3000加入好友 查看LULU3000的个人资料 搜索LULU3000在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 引用回复这个贴子 回复这个贴子 查看LULU3000的博客7
    发贴心情 
    这样行吗:

    <?xml version="1.0" encoding="gb2312"?>
    <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">

    <xsl:template match="/root">
    <html>
    <head>
    <TITLE>测试</TITLE>
    </head>
    <body>
    <xsl:for-each select="Row">
    <tr>
    <xsl:apply-templates select="Cell/Data" />
    <br/>
    </tr>
    </xsl:for-each>
    </body>
    </html>
    </xsl:template>


    <xsl:template match="Cell/Data">
    <td>
    <xsl:value-of select ='.' />
    </td>
    </xsl:template>


    </xsl:stylesheet>

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/1/22 23:43:00
     
     hyl_fr 帅哥哟,离线,有人找我吗?
      
      
      等级:大二(研究汇编)
      文章:40
      积分:239
      门派:XML.ORG.CN
      注册:2004/12/31

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给hyl_fr发送一个短消息 把hyl_fr加入好友 查看hyl_fr的个人资料 搜索hyl_fr在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 引用回复这个贴子 回复这个贴子 查看hyl_fr的博客8
    发贴心情 
    可以根据兼容不同的版本吗?
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/2/4 16:33:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2025/9/22 7:53:03

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

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