AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / user-22459253

AJW's questions

Martin Hope
AJW
Asked: 2024-12-03 23:30:17 +0800 CST

XSLT 匹配另一个 XML 节点中的条目并返回相应的元素

  • 5

免责声明:我仍在学习 XML/XSLT,因此如果这太简单的话请原谅。

我正在尝试在节点 A 中查找一个元素,将其与节点 B 中的类似元素匹配,并将从节点 B 的条目返回到节点 A。

即找到与EmployeeTimeValuationResult/bookingDate匹配的EmployeeTimeSheetEntry下的startDate,并返回相应的cust_Overtime_HR_Action元素:

在此处输入图片描述

我正在尝试使用一个密钥来生成查找(基于这个问题的答案:当在另一个节点中查找标记时,打印逗号分隔的标记),但我不清楚将apply-templates语句放在哪里并检索节点(我现在非常困惑,一直在兜圈子)。

示例源 XML:

<EmployeeTimeSheet>
<EmployeeTimeSheet>
  <employeeTimeSheetEntry>
    <EmployeeTimeSheetEntry>
      <cust_Overtime_HR_ACTION>TOIL</cust_Overtime_HR_ACTION>
      <startDate>2024-11-25T00:00:00.000</startDate>
    </EmployeeTimeSheetEntry>
    <EmployeeTimeSheetEntry>
      <cust_Overtime_HR_ACTION>TOIL</cust_Overtime_HR_ACTION>
      <startDate>2024-11-27T00:00:00.000</startDate>
    </EmployeeTimeSheetEntry>
    <EmployeeTimeSheetEntry>
      <cust_Overtime_HR_ACTION>Payout</cust_Overtime_HR_ACTION>
      <startDate>2024-11-30T00:00:00.000</startDate>
    </EmployeeTimeSheetEntry>
  </employeeTimeSheetEntry>
  <employeeTimeValuationResult>
    <EmployeeTimeValuationResult>
      <bookingDate>2024-11-25T00:00:00.000</bookingDate>
    </EmployeeTimeValuationResult>
  </employeeTimeValuationResult>
</EmployeeTimeSheet>

这是我在 XSLT 中尝试(但失败了)做的事情:

<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<!-- generate lookup table - must be top level, i.e. before template match -->
<xsl:key name="timeSheetEntry" match="EmployeeTimeSheet/EmployeeTimeSheet/employeeTimeSheetEntry/EmployeeTimeSheetEntry" use="startDate"/>

<xsl:template match="/">

<EmployeeTimeSheet>

<!-- retrieve cust_Overtime_HR_ACTION where the bookingDate matches the startDate in above lookup -->
<xsl:template match="/">
    <xsl:apply-templates select="key('timeSheetEntry', EmployeeTimeSheet/EmployeeTimeSheet/employeeTimeValuationResult/EmployeeTimeValuationResult/bookingDate)/cust_Overtime_HR_ACTION"/>
</xsl:template>
    <xsl:for-each select="EmployeeTimeSheet/EmployeeTimeSheet">
        <xsl:for-each select="employeeTimeValuationResult/EmployeeTimeValuationResult">
            <xsl:variable name="var_TimeValResult" select="./*"></xsl:variable>
                <EmployeeTimeSheet>
                    <xsl:copy-of select="$var_TimeValResult"/>
                    
                    <xsl:template match="cust_Overtime_HR_ACTION"> 
                    <overtimeHRaction>                  
                        <xsl:value-of select="."/>
                    </overtimeHRaction> 
                    </xsl:template> 
                    
                </EmployeeTimeSheet>
            </xsl:for-each>
        </xsl:for-each>  <!-- EmployeeTimeSheet/EmployeeTimeSheet -->
</EmployeeTimeSheet> 
</xsl:template> 

</xsl:样式表>

(对于初级水平的代码,深表歉意)

输出应如下所示,其中 2024-11-25 的元素cust_Overtime_HR_ACTION添加到EmployeeTimeValuationResult节点:

<EmployeeTimeSheet>
<EmployeeTimeSheet>
  <employeeTimeValuationResult>
    <EmployeeTimeValuationResult>
      <bookingDate>2024-11-25T00:00:00.000</bookingDate>
      <cust_Overtime_HR_ACTION>TOIL</cust_Overtime_HR_ACTION>
    </EmployeeTimeValuationResult>
  </employeeTimeValuationResult>
</EmployeeTimeSheet>

有人能告诉我哪里出错了吗?XSLT 测试工具只是说:

无法使用提供的 XML/XSL 输入生成 XML 文档。样式表编译期间报告了错误

我无法弄清楚检索相应节点所需的逻辑。

非常感谢您提供的任何指导。

谨致问候,AJ

xml
  • 1 个回答
  • 24 Views
Martin Hope
AJW
Asked: 2023-08-28 19:44:09 +0800 CST

XML - 将列转换为单独的行?

  • 6

我对 XML/XSLT 还很陌生,如果这很简单,我深表歉意。我正在尝试转换包含指示向员工付款的列的 XML 文件,以便每笔付款以及该列的员工信息和付款类型都位于单独的行中。

即:

<?xml version='1.0' encoding='UTF-8'?>
<Report>
<Row><col1>ID</col1><col2>NAME</col2><col3>SALARY</col3><col4>BONUS</col4><col5>SICK PAY</col5><col6>CHRISTMAS PAY</col6></Row>
<Row><col1>1001</col1><col2>Joe Bloggs</col2><col3>1500.00</col3><col4>150.00</col4><col5>50.00</col5><col6>0.00</col6></Row>
<Row><col1>1005</col1><col2>Jane Smith</col2><col3>2000.00</col3><col4>250.00</col4><col5>25.00</col5><col6>15.00</col6></Row>
</Report>

对此:

<?xml version='1.0' encoding='UTF-8'?>
<Report>
<Row><ID>1001</ID><NAME>Joe Bloggs</NAME><PAYTYPE>SALARY</PAYTYPE><AMOUNT>1500.00</AMOUNT></Row>
<Row><ID>1001</ID><NAME>Joe Bloggs</NAME><PAYTYPE>BONUS</PAYTYPE><AMOUNT>150.00</AMOUNT></Row>
<Row><ID>1001</ID><NAME>Joe Bloggs</NAME><PAYTYPE>SICKPAY</PAYTYPE><AMOUNT>50.00</AMOUNT></Row>
<Row><ID>1001</ID><NAME>Joe Bloggs</NAME><PAYTYPE>CHRISTMASPAY</PAYTYPE><AMOUNT>0</AMOUNT></Row>
<Row><ID>1005</ID><NAME>Jane Smith</NAME><PAYTYPE>SALARY</PAYTYPE><AMOUNT>2000.00</AMOUNT></Row>
<Row><ID>1005</ID><NAME>Jane Smith</NAME><PAYTYPE>BONUS</PAYTYPE><AMOUNT>250.00</AMOUNT></Row>
<Row><ID>1005</ID><NAME>Jane Smith</NAME><PAYTYPE>SICKPAY</PAYTYPE><AMOUNT>25.00</AMOUNT></Row>
<Row><ID>1005</ID><NAME>Jane Smith</NAME><PAYTYPE>CHRISTMASPAY</PAYTYPE><AMOUNT>15.00</AMOUNT></Row>
</Report>

挑战在于,如果添加更多列(通过其他付款),它需要动态地容纳更多列。这可能吗?

老实说,我不知道从哪里开始。我尝试过根据各种谷歌搜索拼凑一些 XSLT 来尝试输出甚至一列,例如

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>

<xsl:key name="column-name" match="Row[1]/Item" use="count(preceding-sibling::Item)" />

<xsl:template match="/">
    <Table>
        <xsl:for-each select="Report/Row[position() > 1]">
            <Row>
                <xsl:apply-templates select="Item"/>
            </Row>
        </xsl:for-each>
    </Table>
</xsl:template>

<xsl:template match="Item">
    <Column name="{key('column-name', count(preceding-sibling::Item))}">
        <xsl:value-of select="."/>
    </Column>
</xsl:template>

</xsl:stylesheet>

但一点喜悦也没有。有人能指出我正确的方向吗?

非常感谢:) AJ

xml
  • 2 个回答
  • 30 Views

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    重新格式化数字,在固定位置插入分隔符

    • 6 个回答
  • Marko Smith

    为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会?

    • 2 个回答
  • Marko Smith

    VScode 自动卸载扩展的问题(Material 主题)

    • 2 个回答
  • Marko Smith

    Vue 3:创建时出错“预期标识符但发现‘导入’”[重复]

    • 1 个回答
  • Marko Smith

    具有指定基础类型但没有枚举器的“枚举类”的用途是什么?

    • 1 个回答
  • Marko Smith

    如何修复未手动导入的模块的 MODULE_NOT_FOUND 错误?

    • 6 个回答
  • Marko Smith

    `(表达式,左值) = 右值` 在 C 或 C++ 中是有效的赋值吗?为什么有些编译器会接受/拒绝它?

    • 3 个回答
  • Marko Smith

    在 C++ 中,一个不执行任何操作的空程序需要 204KB 的堆,但在 C 中则不需要

    • 1 个回答
  • Marko Smith

    PowerBI 目前与 BigQuery 不兼容:Simba 驱动程序与 Windows 更新有关

    • 2 个回答
  • Marko Smith

    AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String”

    • 1 个回答
  • Martin Hope
    Fantastic Mr Fox msvc std::vector 实现中仅不接受可复制类型 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant 使用 chrono 查找下一个工作日 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor 构造函数的成员初始化程序可以包含另一个成员的初始化吗? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský 为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul C++20 是否进行了更改,允许从已知绑定数组“type(&)[N]”转换为未知绑定数组“type(&)[]”? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann 为什么 {2,3,10} 和 {x,3,10} (x=2) 的顺序不同? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller 在 5.2 版中,bash 条件语句中的 [[ .. ]] 中的分号现在是可选的吗? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench 为什么双破折号 (--) 会导致此 MariaDB 子句评估为 true? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng 为什么 `dict(id=1, **{'id': 2})` 有时会引发 `KeyError: 'id'` 而不是 TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String” 2024-03-20 03:12:31 +0800 CST

热门标签

python javascript c++ c# java typescript sql reactjs html

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve