Coldfusion Export Excel File

Posted on admin
Excel

Java Excel API. JXL provides simple APIs to allow anyone to read or write MS Excel files to and from a Stream in JAVA. Since Coldfusion is currently leveraging one the world’s most powerful and proliferated application platforms, JAVA, we are able to proxy into the JAVA from CF realm and operate JXL.

  • Jul 20, 2013. In one of my previous post for exporting data from cfgrid I had used table formatting method for a spreadsheet file you can see here. Export cfgrid Data or Table Data in Excel, Pdf and CSV Format(ColdFusion - 9) But, I found another efficient way to export a query object to excelsheet rather than using that.
  • The read operation will transform Excel file into ColdFusion query. While the write operation will transform ColdFusion query to Excel file. Prior to purchasing CFXExcel, we strongly suggest you to download CFXExcel evaluation version first from this link. This way, you can assure the custom tag works perfectly in your server environment.

Let’s talk about XLS Exporting in Adobe Coldfusion 9 (Excel Spreadsheets). ColdFusion has this neat little tag called.

It allows the writing of, updating of, and reading of CSV/XLS files in ColdFusion. This is a handy tool for exporting dynamically generated queries.

It can make XLS Exporting in Adobe Coldfusion 9 very simple and easy to implement. For example, generating reports and listings of information. Adobe documented the cfspreadsheet tag as such: Description 1. Manages Excel spreadsheet files 2. Reads a sheet from a spreadsheet file and stores it in a ColdFusion spreadsheet object, query, CSV string, or HTML string. Writes single sheet to a new XLS file from a query, ColdFusion spreadsheet object, or CSV string variable.

Add a sheet to an existing XLS file. The description as outlined above shows that this tag is very useful, and can write XLS files from objects, csv string variables, or html strings. You can also write a custom ColdFusion function to upload an XLS file, read the content, and input it into a database.

Excel

Coldfusion Export Excel Files

However, XLS Exporting in Adobe Coldfusion 9 has its downsides. The problems with using the cfspreadsheet tag arise when your code logic that builds a ColdFusion spreadsheet object becomes lengthy. When manipulating a ColdFusion spreadsheet object, it slows down your code exponentially. This means the more you have to process, the longer it takes to do so. I got to the point where I could pull a 10,000 record cfquery from the database in 3-4 seconds, but it would take me about 4-5 minutes to put together the ColdFusion spreadsheet object and formatting it the way I wanted it. Below is an example of a lengthy ColdFusion spreadsheet object being put together and exported to an.xls file. TheDir=GetDirectoryFromPath(GetCurrentTemplatePath); theFile=theDir & 'ExampleReport.xls'; theSheet = SpreadsheetNew('testSpreadsheet').

Overwrite = 'true' / The first part of the code is a tag, which puts together the directory and spreadsheet variables that will be used to create the final spreadsheet file. Then follows some complex code logic that iterates through a ColdFusion variable called “collection”. This variable I instantiated previously as a ColdFusion structure that holds two cfquery variables, TICKETTYPES and CARDTYPES. I wanted both these queries to be added to the.xls spreadsheet. In this complex code, I iterate through portions of each query, ordering them by a specific date value inside each query row.

So, for example, my.xls spreadsheet would have headers on the top and for each instance of a specific date, include the TICKETTYPES (and then for the second part of the spreadsheet, the CARDTYPES). For two queries of 10,000 rows each (one for TICKETTYPES and one for CARDTYPES) this complex code was taking forever to format a ColdFusion spreadsheet object. So I came up with a simple solution. When you format a query inside the SQL to display the way you want it on the spreadsheet, it offloads work from the ColdFusion server and onto the SQL database. In the end, all I had to do was include the below code to turn the generated cfquery into an.xls spreadsheet. Query = 'collection.CARDTYPES' / The code for the first cfspreadsheet tag takes the first query and writes an.xls file to display records exactly as shown in the query variable. The second cfspreadsheet tag updates the current.xls file and adds a second spreadsheet onto it (Excel Spreadsheets can have multiple pages, or different spreadsheets in the same.xls file).

This brings the entire processing time down from 4-5 minutes, to 4-5 seconds. That’s a HUGE difference!

Sure, I don’t have all the formatting capabilities that ColdFusion allows for me to have. But the point of understanding came when I realized the people using the spreadsheet need everything laid out in simple rows. They didn’t need headers, spacers or data that was spread out in any fashion. They just needed a row-by-row list of raw data. So, this solution worked out perfectly.

This makes XLS Exporting in Adobe Coldfusion 9 very easy to use. Always remember, when programming using a combined group of different languages (i.e. – Adobe ColdFusion 9 with an MS SQL Database) you can always offload work from one to the other, depending on the application. Here, we took a 4-5 minute process in ColdFusion and gave that job to the database, which helped it run in less than 4-5 seconds. Using this methodology, you can program less and achieve more, and produce efficient applications and web sites!