/**
* Copyright © 2002 Instituto Superior Técnico
*
* This file is part of FenixEdu Academic.
*
* FenixEdu Academic is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* FenixEdu Academic is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with FenixEdu Academic. If not, see <http://www.gnu.org/licenses/>.
*/
package org.fenixedu.academic.ui.spring.controller.teacher.authorization;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Vector;
import org.springframework.stereotype.Service;
import com.google.common.base.Charsets;
import com.google.common.base.Splitter;
import com.google.common.io.CharStreams;
@Service
public class CsvService {
public List<Map<String, String>> readCsvFile(File file, String separator, String encoding) throws IOException {
return readCsvFile(new FileInputStream(file), separator, encoding);
}
public List<Map<String, String>> readCsvFile(InputStream stream, String separator, String encoding) throws IOException {
try (InputStreamReader isr = new InputStreamReader(stream, Charsets.UTF_8)) {
String content = CharStreams.toString(isr);
List<String> lines = Splitter.on(System.lineSeparator()).splitToList(content);
List<String> header = null;
List<Map<String, String>> csvContent = new Vector<Map<String, String>>(lines.size());
for (String line : lines) {
String[] parts = line.split(separator);
if (header == null) {
header = new ArrayList<String>();
for (String part : parts) {
header.add(cleanup(part));
}
} else {
int index = 0;
Map<String, String> linemap = new HashMap<String, String>(header.size());
for (String column : header) {
linemap.put(column, access(parts, index++));
}
csvContent.add(linemap);
}
}
return csvContent;
}
}
private String access(String[] parts, int index) {
if (parts.length <= index) {
return null;
}
return cleanup(parts[index]);
}
private String cleanup(String part) {
String value = part.trim();
if (value.startsWith("\"")) {
value = value.replaceAll("\"", "");
}
return value.trim();
}
}