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

    >> 本版讨论XLink, XPointer, XQuery
    [返回] 中文XML论坛 - 专业的XML技术讨论区XML.ORG.CN讨论区 - XML技术『 XQuery/XLink/XPointer/ 』 → 源文件 和问题贴出来了,给我帮助 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 7827 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: 源文件 和问题贴出来了,给我帮助 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     pingosk 帅哥哟,离线,有人找我吗?
      
      
      等级:大一(猛啃高等数学)
      文章:27
      积分:143
      门派:XML.ORG.CN
      注册:2005/11/3

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给pingosk发送一个短消息 把pingosk加入好友 查看pingosk的个人资料 搜索pingosk在『 XQuery/XLink/XPointer/ 』的所有贴子 引用回复这个贴子 回复这个贴子 查看pingosk的博客楼主
    发贴心情 源文件 和问题贴出来了,给我帮助

    部分要转换的xml文件
    <?xml version="1.0" encoding="utf-8" ?>
    <Report>
    <x:PivotField>
       <x:Name>Product Family</x:Name>
       <x:SourceName>[Product].[Product Family]</x:SourceName>
       <x:FilterCaption>Product</x:FilterCaption>
       <x:Orientation>Row</x:Orientation>
       <x:CompareOrderedMembersBy>UniqueName</x:CompareOrderedMembersBy>
       <x:AllIncludeExclude>Include</x:AllIncludeExclude>
       <x:ExcludedMember>
        <x:Name>Non-Consumable</x:Name>
        <x:UniqueName>[Product].[All Products].[Non-Consumable]</x:UniqueName>
       </x:ExcludedMember>
      </x:PivotField>
      <x:PivotField>
       <x:Name>Product Department</x:Name>
       <x:SourceName>[Product].[Product Department]</x:SourceName>
       <x:Orientation>Row</x:Orientation>
       <x:Position>2</x:Position>
       <x:CompareOrderedMembersBy>UniqueName</x:CompareOrderedMembersBy>
       <x:ExcludedMember>
        <x:Name>Dairy</x:Name>
        <x:UniqueName>[Product].[All Products].[Food].[Dairy]</x:UniqueName>
       </x:ExcludedMember>
       <x:ExcludedMember>
        <x:Name>Baked Goods</x:Name>
        <x:UniqueName>[Product].[All Products].[Food].[Baked Goods]</x:UniqueName>
       </x:ExcludedMember>
      </x:PivotField>
      <x:PivotField>
       <x:Name>Product Category</x:Name>
       <x:SourceName>[Product].[Product Category]</x:SourceName>
       <x:Orientation>Row</x:Orientation>
       <x:Position>3</x:Position>
       <x:CompareOrderedMembersBy>UniqueName</x:CompareOrderedMembersBy>
      </x:PivotField>
      <x:PivotField>
       <x:Name>Product Subcategory</x:Name>
       <x:SourceName>[Product].[Product Subcategory]</x:SourceName>
       <x:Orientation>Row</x:Orientation>
       <x:Position>4</x:Position>
       <x:CompareOrderedMembersBy>UniqueName</x:CompareOrderedMembersBy>
       <x:IncludedMember>
        <x:Name>Bagels</x:Name>
        <x:UniqueName>[Product].[All Products].[Food].[Baked Goods].[Bread].[Bagels]</x:UniqueName>
       </x:IncludedMember>
       <x:IncludedMember>
        <x:Name>Sliced Bread</x:Name>
        <x:UniqueName>[Product].[All Products].[Food].[Baked Goods].[Bread].[Sliced Bread]</x:UniqueName>
       </x:IncludedMember>
      </x:PivotField>
      <x:PivotField>
       <x:Name>Brand Name</x:Name>
       <x:SourceName>[Product].[Brand Name]</x:SourceName>
       <x:Orientation>Row</x:Orientation>
       <x:Position>5</x:Position>
       <x:CompareOrderedMembersBy>UniqueName</x:CompareOrderedMembersBy>
       <x:ExcludedMember>
        <x:Name>Colony</x:Name>
        <x:UniqueName>[Product].[All Products].[Food].[Baked Goods].[Bread].[Sliced Bread].[Colony]</x:UniqueName>
       </x:ExcludedMember>
      </x:PivotField>
      <x:PivotField>
       <x:Name>Product Name</x:Name>
       <x:SourceName>[Product].[Product Name]</x:SourceName>
       <x:CompareOrderedMembersBy>UniqueName</x:CompareOrderedMembersBy>
      </x:PivotField>
    </Report>
    解释:
    这是一个多维的数据
    所有x:SourceName  中第一个[]内相同的都 是一个维,,然后一个维可以有多个级别
    [Product].[Product Family]
    [Product].[Product Department],[Product].[Product Category]
    [Product].[Product Subcategory]
    [Product].[Brand Name]
    [Product].[Product Name]都 是product的级别


    现在我想完成这样一个任务:
    我首先选择在poduct维度中的所有excludedmember元素
    <xsl:for-each select="//x:ExcludedMember[substring-before(x:UniqueName,'.')='[Product']">

    第二步 我想选择它的x:ExcludedMember子元素(可能很多),x:ExcludedMember底下有x:UniqueName元素.
    文档中的其它地方还有x:IncludedMember/x:UniqueName元素,问题是我不想选择满足starts-with(文档中任何x:IncludedMember/x:UniqueName,我当前处理的x:ExcludedMember的x:UniqueName)的那些x:ExcludeMember元素,于是我又加了句这样的代码

    not (//x:IncludedMember[starts-with(x:UniqueName,./x:UniqueName)])]">
    然后我想把所有的这样的元素的x:UniqueName用,号连起来,但最后一个不要

    所以 总的xsl代码 是
    <?xml version="1.0" encoding="gb2312" ?>
    <xsl:stylesheet version="1.0" xmlns="http://schemas.microsoft.com/sqlserver/reporting/2003/10/reportdefinition"
    xmlns:xsl="http://www.w3.org/1999/XSL/Transform"  xmlns:x="urn:schemas-microsoft-com:office:excel">
    <xsl:template name="add">
    <xsl:for-each select="//x:ExcludedMember[substring-before(x:UniqueName,'.')='[Product'][not (//x:IncludedMember[starts-with(x:UniqueName,current()/x:UniqueName)])]">
    Descendants(<xsl:value-of select="x:UniqueName" />)     <xsl:if test="position()!=last()">
        ,
        </xsl:if>
      </xsl:for-each>
    </xsl:template>
    </xsl:stylesheet>
    但结果和我想要的是不同的,

    不知该如何是好
    (中间在贴的时候.有所修改,有点语法错误,见谅,我不会出那方面的原因)

    [此贴子已经被作者于2005-11-19 12:49:56编辑过]

       收藏   分享  
    顶(0)
      




    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/11/18 23:03:00
     
     菜籽 帅哥哟,离线,有人找我吗?双鱼座1981-2-28
      
      
      威望:5
      头衔:软件民工
      等级:研二(Sowa的知识表示写得真好!)
      文章:875
      积分:5655
      门派:XML.ORG.CN
      注册:2004/7/25

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给菜籽发送一个短消息 把菜籽加入好友 查看菜籽的个人资料 搜索菜籽在『 XQuery/XLink/XPointer/ 』的所有贴子 点击这里发送电邮给菜籽 引用回复这个贴子 回复这个贴子 查看菜籽的博客2
    发贴心情 
    <xsl:template>
    </xsl:stylesheet>
    应该是
    </xsl:template>
    </xsl:stylesheet>

    ----------------------------------------------
    重拾英语...

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/11/19 10:43:00
     
     pingosk 帅哥哟,离线,有人找我吗?
      
      
      等级:大一(猛啃高等数学)
      文章:27
      积分:143
      门派:XML.ORG.CN
      注册:2005/11/3

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给pingosk发送一个短消息 把pingosk加入好友 查看pingosk的个人资料 搜索pingosk在『 XQuery/XLink/XPointer/ 』的所有贴子 引用回复这个贴子 回复这个贴子 查看pingosk的博客3
    发贴心情 
    对,,我马上改过来
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/11/19 12:49:00
     
     菜籽 帅哥哟,离线,有人找我吗?双鱼座1981-2-28
      
      
      威望:5
      头衔:软件民工
      等级:研二(Sowa的知识表示写得真好!)
      文章:875
      积分:5655
      门派:XML.ORG.CN
      注册:2004/7/25

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给菜籽发送一个短消息 把菜籽加入好友 查看菜籽的个人资料 搜索菜籽在『 XQuery/XLink/XPointer/ 』的所有贴子 点击这里发送电邮给菜籽 引用回复这个贴子 回复这个贴子 查看菜籽的博客4
    发贴心情 
    这样可以么?

    <?xml version="1.0" encoding="gb2312" ?>
    <xsl:stylesheet version="1.0" xmlns="http://schemas.microsoft.com/sqlserver/reporting/2003/10/reportdefinition"
    xmlns:xsl="http://www.w3.org/1999/XSL/Transform"  xmlns:x="urn:schemas-microsoft-com:office:excel">
    <xsl:template name="add">
    <xsl:for-each select="//x:ExcludedMember[substring-before(x:UniqueName,'.')='[Product'][not (//x:IncludedMember[starts-with(x:UniqueName,//x:ExcludedMember/x:UniqueName)])]">
    Descendants(<xsl:value-of select="x:UniqueName" />)     <xsl:if test="position()!=last()">
        ,
        </xsl:if>
      </xsl:for-each>
    </xsl:template>
    </xsl:stylesheet>

    ----------------------------------------------
    重拾英语...

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/11/19 14:17:00
     
     pingosk 帅哥哟,离线,有人找我吗?
      
      
      等级:大一(猛啃高等数学)
      文章:27
      积分:143
      门派:XML.ORG.CN
      注册:2005/11/3

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给pingosk发送一个短消息 把pingosk加入好友 查看pingosk的个人资料 搜索pingosk在『 XQuery/XLink/XPointer/ 』的所有贴子 引用回复这个贴子 回复这个贴子 查看pingosk的博客5
    发贴心情 
    我试试看
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/11/19 15:05:00
     
     pingosk 帅哥哟,离线,有人找我吗?
      
      
      等级:大一(猛啃高等数学)
      文章:27
      积分:143
      门派:XML.ORG.CN
      注册:2005/11/3

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给pingosk发送一个短消息 把pingosk加入好友 查看pingosk的个人资料 搜索pingosk在『 XQuery/XLink/XPointer/ 』的所有贴子 引用回复这个贴子 回复这个贴子 查看pingosk的博客6
    发贴心情 
    不行啊,大哥
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/11/20 14:05:00
     
     pingosk 帅哥哟,离线,有人找我吗?
      
      
      等级:大一(猛啃高等数学)
      文章:27
      积分:143
      门派:XML.ORG.CN
      注册:2005/11/3

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给pingosk发送一个短消息 把pingosk加入好友 查看pingosk的个人资料 搜索pingosk在『 XQuery/XLink/XPointer/ 』的所有贴子 引用回复这个贴子 回复这个贴子 查看pingosk的博客7
    发贴心情 
    以下是我的解决方法
     <xsl:template name="FilterExcludedMember">
      <xsl:param name="Index" select="1" />
      <xsl:param name="Visited" select="0" /><!--这里为什么不能用字符串"False"-->
      <xsl:param name="Super" />
      <xsl:if test="$Index &lt;= count(//x:ExcludedMember)">
       <xsl:variable name="Temp" select="//x:ExcludedMember[substring-before(x:UniqueName,'.')=substring-before($Super,'.')][position()=$Index]/x:UniqueName" />
       <xsl:choose>
        <xsl:when test="not (//x:IncludedMember[starts-with(x:UniqueName,$Temp)]) and $Visited =0">
        Descendants(<xsl:value-of select="$Temp" />)
        <xsl:call-template name="FilterExcludedMember">
          <xsl:with-param name="Visited">
           <xsl:value-of select="1" />
          </xsl:with-param>
          <xsl:with-param name="Index">
           <xsl:value-of select="$Index + 1" />
          </xsl:with-param>
          <xsl:with-param name="Super">
           <xsl:value-of select="$Super" />
          </xsl:with-param>
         </xsl:call-template>
        </xsl:when>
        <xsl:when test="not (//x:IncludedMember[starts-with(x:UniqueName,$Temp)]) and $Visited =1">
        ,Descendants(<xsl:value-of select="$Temp" />)
        <xsl:call-template name="FilterExcludedMember">
          <xsl:with-param name="Visited">
           <xsl:value-of select="1" />
          </xsl:with-param>
          <xsl:with-param name="Index">
           <xsl:value-of select="$Index + 1" />
          </xsl:with-param>
          <xsl:with-param name="Super">
           <xsl:value-of select="$Super" />
          </xsl:with-param>
         </xsl:call-template>
        </xsl:when>
        <xsl:otherwise>
         <xsl:call-template name="FilterExcludedMember">
          <xsl:with-param name="Visited">
           <xsl:value-of select="$Visited" />
          </xsl:with-param>
          <xsl:with-param name="Index">
           <xsl:value-of select="$Index + 1" />
          </xsl:with-param>
          <xsl:with-param name="Super">
           <xsl:value-of select="$Super" />
          </xsl:with-param>
         </xsl:call-template>
        </xsl:otherwise>
       </xsl:choose>
      </xsl:if>
      <xsl:if test="$Index &gt; count(//x:ExcludedMember) and //x:PivotField[x:IncludedMember][substring-before(x:SourceName,']')=substring-before($Super,']')] and $Visited =1 ">
            ,
       </xsl:if>
     </xsl:template>
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/11/20 15:46:00
     
     菜籽 帅哥哟,离线,有人找我吗?双鱼座1981-2-28
      
      
      威望:5
      头衔:软件民工
      等级:研二(Sowa的知识表示写得真好!)
      文章:875
      积分:5655
      门派:XML.ORG.CN
      注册:2004/7/25

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给菜籽发送一个短消息 把菜籽加入好友 查看菜籽的个人资料 搜索菜籽在『 XQuery/XLink/XPointer/ 』的所有贴子 点击这里发送电邮给菜籽 引用回复这个贴子 回复这个贴子 查看菜籽的博客8
    发贴心情 
    你的问题解决了么?

    ----------------------------------------------
    重拾英语...

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/11/20 23:06:00
     
     pingosk 帅哥哟,离线,有人找我吗?
      
      
      等级:大一(猛啃高等数学)
      文章:27
      积分:143
      门派:XML.ORG.CN
      注册:2005/11/3

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给pingosk发送一个短消息 把pingosk加入好友 查看pingosk的个人资料 搜索pingosk在『 XQuery/XLink/XPointer/ 』的所有贴子 引用回复这个贴子 回复这个贴子 查看pingosk的博客9
    发贴心情 
    用我的方法解决了
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2005/11/21 17:06:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 XQuery/XLink/XPointer/ 』的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/5/10 6:23:52

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

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