我正在尝试使用cfspreadsheet读取一个在多个选项卡上有预定义图表的电子表格,但当涉及到处理数据时,我得到的变量是未定义的。
我使用了Adobe - http://help.adobe.com/en_US/ColdFusion/9.0/CFMLRef/WSc3ff6d0ea77859461172e0811cbec17cba-7f87.html中的示例
我还查看了其他示例,但这些示例使用cfspreadsheet和poi或java的组合,如果可能的话,我更喜欢只使用cfspreadsheet。你知道我下面的代码问题是从哪里来的吗?谢谢。
<cfcontent type="application/vnd.ms-excel" reset="Yes">
<cfquery name="GetData" datasource="#request.dsn#">
SELECT *
FROM v_Occurrences
</cfquery>
<cfset strFileName = "OccurrenceData" & "#now().getTime()#" & "#UserID#">
<!---
<cfdump var="#GetData#">
--->
<cfset filepath = "file:///...OccurenceData.xls">
<!--- Write the two sheets to a single file --->
<cfspreadsheet
action ="read"
columnnames = "Occurence_Date,Full_Name_Client"
columns = "2"
excludeHeaderRow = "false"
headerrow = "1"
query="GetData"
rows = "2"
src ="#filepath#">
<cfscript>
OccurrenceData = SpreadsheetNew("Data");
Month = SpreadsheetNew("Month");
Person = SpreadsheetNew("Person");
SpreadsheetAddRows(occurrencedata,getdata);
</cfscript>
<!--- Write the two sheets to a single file --->
<cfspreadsheet
action="write"
filename="#filepath#"
name="OccurrenceData"
overwrite="true"
sheetname="Data" >
<cfspreadsheet
action="Update"
filename="#filepath#"
name="Month"
sheetname="Month">
<cfspreadsheet
action="Update"
filename="#filepath#"
name="Person"
sheetname="Person" >
<cfspreadsheet
action="read"
src="#filepath#"
sheetname="occurrencedata"
query="GetData"> 这里是错误发生的地方:变量Occurrence_Data未定义
<cfscript>
SpreadsheetAddRow(OccurrenceData,"Date,Name",1,1);
SpreadsheetAddRow(OccurrenceData,
"#Dateformat(Occurrence_Date,'mm/dd/yyyy')#,#Full_Name_Client#",
2,1,true);
</cfscript>
<cfspreadsheet
action="write"
autosize="true"
filename="#strFileName#.xls"
overwrite="true"
password="password"
query="GetData"
sheetname="Data" > 发布于 2017-02-16 04:26:32
问题1.这可能弊大于利。
<cfcontent type="application/vnd.ms-excel" reset="Yes">问题2.如果你想把两个工作表写到一个文件中,你不需要这样做:
OccurrenceData = SpreadsheetNew("Data");
Month = SpreadsheetNew("Month"); 你可以这样做:
OccurrenceData = SpreadsheetNew("Data");
// do stuff with this sheet
SpreadsheetCreateSheet(OccurrenceData, "Month");
SpreadSheetSetActiveSheetNumber(OccurrenceData, 2);
// do stuff with this sheet
SpreadSheetWrite(OccurrenceData, whateverYourFileNameIs);我还建议你一次做一件事。编写一些代码,运行它,然后查看结果。然后添加更多的代码,运行它,并查看结果。这将帮助您隔离导致错误的代码。
https://stackoverflow.com/questions/42258339
复制相似问题