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

tech.tablesaw.api.Row Maven / Gradle / Ivy

package tech.tablesaw.api;

import tech.tablesaw.columns.Column;
import tech.tablesaw.columns.dates.PackedDate;
import tech.tablesaw.columns.datetimes.PackedDateTime;
import tech.tablesaw.columns.times.PackedTime;

import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.LocalTime;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;

public class Row implements Iterator {

    private int rowNumber;
    private final Table table;
    private final Map dateColumnMap = new HashMap<>();
    private final Map numberColumnMap = new HashMap<>();
    private final Map stringColumnMap = new HashMap<>();
    private final Map booleanColumnMap = new HashMap<>();
    private final Map dateTimeColumnMap = new HashMap<>();
    private final Map timeColumnMap = new HashMap<>();

    public Row(Table table) {
        this.table = table;
        rowNumber = -1;
        for (Column column : table.columns()) {

            if (column instanceof DateColumn) {
                dateColumnMap.put(column.name(), new PackedDate((DateColumn) column));
            } else if (column instanceof DoubleColumn) {
                numberColumnMap.put(column.name(), (NumberColumn) column);
            } else if (column instanceof StringColumn) {
                stringColumnMap.put(column.name(), (StringColumn) column);
            } else if (column instanceof BooleanColumn) {
                booleanColumnMap.put(column.name(), (BooleanColumn) column);
            } else if (column instanceof DateTimeColumn) {
                dateTimeColumnMap.put(column.name(), new PackedDateTime((DateTimeColumn) column));
            } else if (column instanceof TimeColumn) {
                timeColumnMap.put(column.name(), new PackedTime((TimeColumn) column));
            } else {
                throw new RuntimeException("Unsupported Column type in column " + column);
            }
        }
    }

    @Override
    public boolean hasNext() {
        return rowNumber < table.rowCount() - 1;
    }

    /**
     * Returns a list containing the names of each column in the row
     */
    public List columnNames() {
        return table.columnNames();
    }

    public int columnCount() {
        return table.columnCount();
    }

    @Override
    public Row next() {
        rowNumber++;
        return this;
    }

    public double getDouble(String columnName) {
        return numberColumnMap.get(columnName).get(rowNumber);
    }

    public int getInt(String columnName) {
        return (int) numberColumnMap.get(columnName).get(rowNumber);
    }

    public String getString(String columnName) {
        return stringColumnMap.get(columnName).get(rowNumber);
    }

    public LocalDate getDate(String columnName) {
        return getPackedDate(columnName).asLocalDate();
    }

    public PackedDate getPackedDate(String columnName) {
        return dateColumnMap.get(columnName).get(rowNumber);
    }

    public LocalTime getTime(String columnName) {
        return getPackedTime(columnName).asLocalTime();
    }

    public LocalDateTime getDateTime(String columnName) {
        return getPackedDateTime(columnName).asLocalDateTime();
    }

    public PackedTime getPackedTime(String columnName) {
        return timeColumnMap.get(columnName).get(rowNumber);
    }

    public PackedDateTime getPackedDateTime(String columnName) {
        return dateTimeColumnMap.get(columnName).get(rowNumber);
    }

    public boolean getBoolean(String columnName) {
        return booleanColumnMap.get(columnName).get(rowNumber);
    }

    public double getDouble(int columnIndex) {
        return numberColumnMap.get(columnNames().get(columnIndex)).get(rowNumber);
    }

    public int getInt(int columnIndex) {
        return (int) numberColumnMap.get(columnNames().get(columnIndex)).get(rowNumber);
    }

    public String getString(int columnIndex) {
        return stringColumnMap.get(columnNames().get(columnIndex)).get(rowNumber);
    }

    public LocalDate getDate(int columnIndex) {
        return getPackedDate(columnNames().get(columnIndex)).asLocalDate();
    }

    public PackedDate getPackedDate(int columnIndex) {
        return dateColumnMap.get(columnNames().get(columnIndex)).get(rowNumber);
    }

    public LocalTime getTime(int columnIndex) {
        return getPackedTime(columnNames().get(columnIndex)).asLocalTime();
    }

    public LocalDateTime getDateTime(int columnIndex) {
        return getPackedDateTime(columnNames().get(columnIndex)).asLocalDateTime();
    }

    public PackedTime getPackedTime(int columnIndex) {
        return timeColumnMap.get(columnNames().get(columnIndex)).get(rowNumber);
    }

    public PackedDateTime getPackedDateTime(int columnIndex) {
        return dateTimeColumnMap.get(columnNames().get(columnIndex)).get(rowNumber);
    }

    public boolean getBoolean(int columnIndex) {
        return booleanColumnMap.get(columnNames().get(columnIndex)).get(rowNumber);
    }

    public void at(int rowNumber) {
        this.rowNumber = rowNumber;
    }

    public int getRowNumber() {
        return rowNumber;
    }

    @Override
    public String toString() {
        Table t = table.emptyCopy();
        if (getRowNumber() == -1) {
            return "";
        }
        t.addRow(this);
        return t.print();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy