如何在ColdFusion 2016中动态设置电子表格自动过滤器?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何在ColdFusion 2016中动态设置电子表格自动过滤器?相关的知识,希望对你有一定的参考价值。
我想动态地将自动过滤器添加到电子表格第一行中的所有列。这是我到目前为止的例子:
SpreadSheetAddAutoFilter(theSheet,"A1:Z1");
这有效,但问题是如果我的文件中有更少或更多的列。有没有办法在我的文件的第一行中的每一列上设置过滤器?这不应该是硬编码的。如果您有任何关于此问题的示例,请告诉我。谢谢。
答案
假设您已经有一个Excel工作表,并且正在尝试动态地将过滤器添加到整个行,您需要这样做
- 获取列数
- 将列数转换为相应的字母。例如,列E - > 5
- 从中创建一个范围,例如
A1:E1
,并将该字符串传递给SpreadSheetAddAutoFilter()
函数。
这是我写的一个工作示例:
<cffunction name="columnToLetter" returntype="any">
<cfargument name="index" type="numeric">
<cfset letterArray = listToArray('A B C D E F G H I J K L M N O P Q R S T U V W X Y Z', ' ')>
<cfreturn letterArray[index]>
</cffunction>
<cfspreadsheet action="read" src="fin.xlsx" name="spreadSheetObj" sheetname="Sheet1">
<cfset count = SpreadsheetGetColumnCount(spreadSheetObj, 'Sheet1')>
<cfoutput>
count: #count# <br>
<cfset column_label = columnToLetter(count)>
<cfset column_label = 'A1:' & column_label & '1'>
label: #column_label#
<cfset SpreadSheetAddAutoFilter(spreadSheetObj, column_label)>
<cfspreadsheet action="write" filename="updatedFile.xls" name="spreadSheetObj" sheetname="courses" overwrite=true>
</cfoutput>
另一答案
发布此答案,因为它比已发布的答案具有更好的结果。这只是一个简单的循环,由26
划分并获得角色。
<cfscript>
// Function to print Excel column name for a given column number
function printString(n){
str = '';
while (n>0){
// Find remainder
rem = n%26;
// If remainder is 0, then a 'Z' must be there in output
if (rem==0){
str = 'Z' & str;
n = (n26)-1;
} else {
str = chr(64 + rem) & str;
n = n26;
}
}
return str;
}
</cfscript>
缩短形式
function printString(n){
str = '';
while (n>0){
rem = n%26;
str = rem==0 ? 'Z' & str : chr(64 + rem) & str;
n = rem==0 ? (n26)-1 : n26;
}
return str;
}
以上是关于如何在ColdFusion 2016中动态设置电子表格自动过滤器?的主要内容,如果未能解决你的问题,请参考以下文章
如何检查ColdFusion 2016中是否存在cookie?