双重评估 - 如何根据保存列名称的变量访问我的查询列?

发布于 2024-10-14 01:04:27 字数 555 浏览 11 评论 0原文

我有一个查询和一个字段/列名称列表。我想做一种双循环 - 循环查询中的每个记录,然后循环字段/列名称列表并输出每个相应的字段。循环应该是这样的:

<table>
    <cfoutput query="myQuery">
        <tr>
            <cfloop list="#cols#" index="col">
                <td>?</td>
            </cfloop>
        </tr>
    </cfoutput>
</table>

问题是在问号所在的位置放置什么...我已经尝试过#myquery[col]#,但这不起作用。我需要获取变量 col 中的字符串名称指示的变量...显然,#col# 将只返回列名称。我需要找出某种方法来双重评估字符串...类似于 ##col## ,这当然也行不通。我怎样才能做到这一点?

I have a query and a list of field/column names. I want to do a sort of double loop - loop through each record in the query, and then loop through the list of field/column names and output each corresponding field. The loops should be something like this:

<table>
    <cfoutput query="myQuery">
        <tr>
            <cfloop list="#cols#" index="col">
                <td>?</td>
            </cfloop>
        </tr>
    </cfoutput>
</table>

The problem is what to put where the question mark is... I've tried #myquery[col]#, but this didn't work. I need to get the variable indicated by the string name in the variable col... And obviously, #col# will just return the column name. I need to figure out some way to double-evaluate the string... something like ##col##, which of course won't work either. How can I accomplish this?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

怪我鬧 2024-10-21 01:04:27

当将列名作为结构引用时,您还需要告诉查询您想要获取哪一行。如果您没有通过 myQuery.ColumnList 获取 cols 变量,您还应该确保检查列名是否存在。

使用以下代码动态引用循环中的每一列:

<table>
    <cfoutput query="myQuery">
        <tr>
            <cfloop list="#cols#" index="col">
                <td>#myQuery[col][CurrentRow]#</td>
            </cfloop>
        </tr>
    </cfoutput>
</table>

When referencing column names as a structure, you need to also tell the query which row you want to get. You should also make sure that you check that the column name exists if you didn't get the cols variable via myQuery.ColumnList.

Use the following code to dynamically reference each column in your loop:

<table>
    <cfoutput query="myQuery">
        <tr>
            <cfloop list="#cols#" index="col">
                <td>#myQuery[col][CurrentRow]#</td>
            </cfloop>
        </tr>
    </cfoutput>
</table>
那小子欠揍 2024-10-21 01:04:27

您仍然可以将 Sergii 的方法用于您自己的专栏列表:

<cfloop list="#cols#" index="col">
   <cfif StructKeyExists(myQuery, col)>
      <td>#col# = #myQuery[col][myQuery.CurrentRow]#</td>
   </cfif>
</cfloop>

You can still use Sergii's approach with your own columnlist:

<cfloop list="#cols#" index="col">
   <cfif StructKeyExists(myQuery, col)>
      <td>#col# = #myQuery[col][myQuery.CurrentRow]#</td>
   </cfif>
</cfloop>
暮年 2024-10-21 01:04:27

知道了!! :)

#evaluate(evaluate("col"))#

Got it!! :)

#evaluate(evaluate("col"))#
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文