gpt4 book ai didi

xml - ColdFusion 问题 : Reading Value of XML Child as Empty String

转载 作者:数据小太阳 更新时间:2023-10-29 02:34:06 24 4
gpt4 key购买 nike

我目前使用的是 ColdFusion 10/11,对它还是比较陌生。我通常使用 PHP/C# 编写代码,因此使用脚本语言(如果您这么调用它)来管理 XML 数据的概念对我来说有点奇怪。如果我可以用 PHP 重新设计 Web 应用程序,我会的,但不幸的是,现在这不是一个选项。

就平台而言,我不使用 Adob​​e ColdFusion Builder 或 CF Administrator。我正在使用 Dreamweaver 和 CFEclipse。

所以,现在我正在读取一个 XML 文件并检查 XML 子文件是否包含"is"、“否”等并显示相应的标签。它以前工作正常,但我必须向名为“GNTrained”的 XML 文件添加一个新的子文件。

添加新元素后,还是说该值为空字符串。我使用“structKeyExists”来验证子项是否存在,但该值仍然为空。

我还验证了它正在读取正确的 XML 文件。伟大的 ColdFusion 引用文献不再在线存在(尽管,我不确定它们是否曾经存在过)所以任何帮助将不胜感激!

知道为什么会发生这种情况吗?
XML 位置将委托(delegate)给其他任何地方?

我已经多次尝试修改它,但仍然想知道为什么该值仍然是一个空字符串。我已经尝试了各种不同的值,交换了周围的元素,任何东西都可以让它工作。

为了我的工作,这是示例代码,而不是我正在使用的确切代码集。所以如果我遗漏了什么,请告诉我。然而,这是最简单的代码版本,我认为这真的是解决这个问题所需要的。

有3个不同的文件:前端显示文件、查询文件和XML文件。

显示页面的代码如下:

<cfinclude template="#APPLICATION.root#employee/details/employee-query.cfm" />
<cfoutput>
<cfquery name="get_employee" dbtype="query">
SELECT id,name,GNTrained from session.employeeDetails order by name
</cfquery>
<cfloop query="get_employee">
<cfif tr eq "RowEven">
<cfset tr="RowOdd">
<cfelse>
<cfset tr="RowEven">
</cfif>
<li class="EmployeeRow #tr#" id="company_#get_employee.currentrow#">#htmleditformat(get_employee.name)#
<div id="bfeat_#get_employee.currentrow#" class="Hidden">
<div class="employeeGroup" style="width:371px;">
<ul class="EmpTrainingList">
<li>BBTrained:
<cfif get_employee.BBTrained contains "YES">
<span class="yes">#get_employee.BBTrained#</span>
<cfelse>
<span class="no">#get_employee.BBTrained#</span>
</cfif>
</li>
<li>GNTrained:
<cfif structKeyExists( get_employee, "GNTrained" )>
<span style="color: red;"><strong>EXISTS! </strong></span>
<cfelse> DOES NOT EXIST!
</cfif>
<cfif get_employee.GNTrained contains "YES">
<span class="yes">#get_employee.GNTrained#</span>
<cfelseif get_employee.GNTrained contains "In Progress">
<span class="in-progress">#get_employee.GNTrained#</span>
<cfelseif get_employee.GNTrained eq "">
<span class="no">EMPTY</span>
<cfelse>
<span class="no">#get_employee.GNTrained#</span>
</cfif>
</li>
</ul>
</div>
</div>
</li>
</cfloop>
</cfoutput>

查询代码如下:

<cffile action="read" file="#ExpandPath('#application.root#cf_test/employeeDetails.xml')#" variable="myxml">

<cfset mydoc = XmlParse(myxml)>
<cfset apps = mydoc.data.XmlChildren>
<cfset size = ArrayLen(apps)>

<cfset session.employeeDetails = QueryNew("employee_id,employee_name,GNTrained") >
<cfset temp = QueryAddRow(session.employeeDetails, #size#)>

<cfloop index="i" from = "1" to = #size#>
<cfloop index="x" from="1" to="8">
<cfset attr_name = REReplace(#mydoc.data.employees[i].XMLChildren[x].xmlName#, "[^a-zA-Z0-9__]", "", "ALL") />
<cfset temp = QuerySetCell(session.employeeDetails, "#attr_name#",
#mydoc.data.employees[i].XMLChildren[x].xmlText#, #i#)>
</cfloop>
</cfloop>

<cfcatch>Error loading</cfcatch>
</cftry>

</cfoutput>

这是 XML 文件:

<!---- File Name: employeeDetails.xml ---->
<?xml version="1.0" encoding="utf-8" ?>
<data>
<employees>
<name>John Smith</name>
<id>1234</id>
<BBTrained>NO</BBTrained>
<DEPT>21</DEPT>
<EXP>12</EXP>
<current>YES</current>
<Status>ACTIVE</Status>
<StateCode>CO122</StateCode>
<GNTrained>NO</GNTrained>
</employees>
<employees>
<name>Mary Chapman</name>
<id>3344</id>
<BBTrained>YES</BBTrained>
<DEPT>21</DEPT>
<EXP>18</EXP>
<Status>LOA</Status>
<StateCode>DE255</StateCode>
<GNTrained>YES</GNTrained>
</employees>
<employees>
<name>Alex Fisher</name>
<id>6655</id>
<BBTrained>NO</BBTrained>
<DEPT>22</DEPT>
<EXP>6</EXP>
<Status>ACTIVE</Status>
<StateCode>ME255</StateCode>
<GNTrained>YES</GNTrained>
</employees>
</data>

更新代码 - 现在包括 cfloop。 (4/20/16)

**解决方案:** 在 SpliFF 的帮助下,我找到了问题所在。说真的,这是我遇到过的最简单的修复方法之一。在查询页面的以下代码中:

我需要将“8”更改为“9”以说明新元素。是的……真的是那么小的变化。 感叹

最佳答案

当您构建查询时,您只是将 temp 设置为第 1 行,因为您的 QueryAddRow 在循环之外。您需要它指向每个 XML 子项的当前行:

<cfloop index="i" from = "1" to = #size#>
<cfset temp = QueryAddRow(session.employeeDetails)>
<cfloop index="x" from="1" to="#ArrayLen(mydoc.data.employees[i].XMLChildren)#">
<cfset attr_name = REReplace(#mydoc.data.employees[i].XMLChildren[x].xmlName#, "[^a-zA-Z0-9__]", "", "ALL") />
<cfset QuerySetCell(session.employeeDetails, "#attr_name#",
#mydoc.data.employees[i].XMLChildren[x].xmlText#, #i#)>
</cfloop>
</cfloop>

关于xml - ColdFusion 问题 : Reading Value of XML Child as Empty String,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36754785/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com