All Downloads are FREE. Search and download functionalities are using the official Maven repository.

metridoc.plugins.table.impl.XLSFileWrapper.groovy Maven / Gradle / Ivy

/*
 * Copyright 2010 Trustees of the University of Pennsylvania Licensed under the
 * Educational Community License, Version 2.0 (the "License"); you may
 * not use this file except in compliance with the License. You may
 * obtain a copy of the License at
 *
 * http://www.osedu.org/licenses/ECL-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an "AS IS"
 * BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
 * or implied. See the License for the specific language governing
 * permissions and limitations under the License.
 */
package metridoc.plugins.table.impl
import org.apache.poi.hssf.usermodel.*
import metridoc.plugins.table.core.*
import metridoc.plugins.Plugin

@Plugin(category="table")
@Mixin(DatasourceCategory)
class XLSFileWrapper implements SortableDatasource{
	def datasource
	def global

	public getInputs(){
		return [
			global:["root":System.properties["user.home"]],
			instance:["file":""]
		]
	}

	private getSheetTitles(sheet){
		return sheet.getRow(0).collect{
			it.toString().replaceAll("[\\#\\\"\\?]+","").trim().replaceAll("\\s+","_").toLowerCase()
		}
	}

	public Object profile(){
		def filePath = getFileLocation(datasource.file)
		def inputStream = new java.io.FileInputStream(filePath)
		def wb = new HSSFWorkbook(inputStream)

		def sheetCount = wb.numberOfSheets

		def xlsKeys = [:]
		def i = 0;
		for(i=0;i
			if(callClosure){
				def rowMap = [:]
				columns.eachWithIndex {coll,i ->
					rowMap[coll] = row.getCell(i).toString()
				}
				closure(rowMap)
			}else{
				callClosure = true
			}
		}
	}	
}





© 2015 - 2024 Weber Informatics LLC | Privacy Policy