/*
* RapidMiner
*
* Copyright (C) 2001-2011 by Rapid-I and the contributors
*
* Complete list of developers available at our web site:
*
* http://rapid-i.com
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program 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 Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see http://www.gnu.org/licenses/.
*/
package com.rapidminer.operator.io;
import java.util.Iterator;
import java.util.List;
import com.rapidminer.operator.OperatorDescription;
import com.rapidminer.parameter.ParameterType;
import com.rapidminer.parameter.ParameterTypeFile;
/**
* <p>This operator can read csv files. All values must be separated by
* "," or by ";", followed by an arbitrary amount of
* white space. This means that also only the separator characters are allowed.
* The first line is used for the attribute names as default. Empty values
* and the question mark will be read as missing values. You can quote
* the values (including the column separators) with a double quote (").
* You can escape the quoting character with a backslash, i.e. \".</p>
*
* <p>For other file formats or column separators you can
* use in almost all cases the operator {@link SimpleExampleSource}
* or, if this is not sufficient, the operator {@link ExampleSource}.</p>
*
* @rapidminer.index csv
* @author Ingo Mierswa
*/
@Deprecated
public class CSVExampleSource extends SimpleExampleSource {
// Removed because of deprecation of this operator
// static {
// AbstractReader.registerReaderDescription(new ReaderDescription("csv", CSVExampleSource.class, PARAMETER_FILENAME));
// }
public CSVExampleSource(OperatorDescription description) {
super(description);
}
@Override
public List<ParameterType> getParameterTypes() {
List<ParameterType> types = super.getParameterTypes();
Iterator<ParameterType> p = types.iterator();
while (p.hasNext()) {
ParameterType type = p.next();
if (type.getKey().equals(PARAMETER_USE_FIRST_ROW_AS_ATTRIBUTE_NAMES)) {
type.setDefaultValue(true);
} else if (type.getKey().equals(PARAMETER_FILENAME)) {
((ParameterTypeFile)type).setExtension("csv");
} else if (type.getKey().equals(PARAMETER_USE_QUOTES)) {
type.setDefaultValue(true);
} else if (type.getKey().equals(PARAMETER_COLUMN_SEPARATORS)) {
type.setDefaultValue(",\\s*|;\\s*");
}
}
return types;
}
}