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

org.supercsv.io.ICsvReader Maven / Gradle / Ivy

There is a newer version: 2.4.0
Show newest version
/*
 * Copyright 2007 Kasper B. Graversen
 * 
 * Licensed under the Apache 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.apache.org/licenses/LICENSE-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 org.supercsv.io;

import java.io.Closeable;
import java.io.IOException;

import org.supercsv.exception.SuperCsvException;

/**
 * The interface for CSV readers.
 * 
 * @author Kasper B. Graversen
 * @author James Bassett
 */
public interface ICsvReader extends Closeable {
	
	/**
	 * Get column N of the current line (column indexes begin at 1).
	 * 
	 * @param n
	 *            the index of the column to get
	 * @return the n'th column
	 * @throws IndexOutOfBoundsException
	 *             if the supplied index is not a valid column index
	 * @since 1.0
	 */
	String get(int n);
	
	/**
	 * This method is used to get an optional header of the CSV file and move the file cursor to the first row
	 * containing data (the second row from the top). The header can subsequently be used as the
	 * nameMapping array for read operations.
	 * 
	 * @param firstLineCheck
	 *            if true, ensures that this method is only called when reading the first line (as that's where the
	 *            header is meant to be)
	 * @return the array of header fields, or null if EOF is encountered
	 * @throws IOException
	 *             if an I/O exception occurs
	 * @throws SuperCsvException
	 *             if firstLineCheck == true and it's not the first line being read
	 * @since 1.0
	 */
	String[] getHeader(boolean firstLineCheck) throws IOException;
	
	/**
	 * Gets the current position in the file, where the first line of the file is line number 1.
	 * 
	 * @return the line number
	 * @since 1.0
	 */
	int getLineNumber();
	
	/**
	 * Returns the untokenized CSV row that was just read (which can potentially span multiple lines in the file).
	 * 
	 * @return the untokenized CSV row that was just read
	 * @since 2.0.0
	 */
	String getUntokenizedRow();
	
	/**
	 * Gets the current row number (i.e. the number of CSV records - including the header - that have been read). This
	 * differs from the lineNumber, which is the number of real lines that have been read in the file. The first row is
	 * row 1 (which is typically the header row).
	 * 
	 * @return the current row number
	 * @since 2.0.0
	 */
	int getRowNumber();
	
	/**
	 * Returns the length (i.e. number of columns) of the current row.
	 * 
	 * @return the length of the current row
	 * @since 1.0
	 */
	int length();
	
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy