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

atlasgen.CsvReader Maven / Gradle / Ivy

There is a newer version: 2023.5
Show newest version
/*
 * Copyright (c) 2023. Manuel Daniel Dahmen
 *
 *
 *    Copyright 2012-2023 Manuel Daniel Dahmen
 *
 *    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 atlasgen; /*__
 * Created by manushell on 19-06-18.
 */

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

public class CsvReader {
    private final int countLineModulo = 10000;
    private final int MAX_LINE_LENGTH_2 = 5000;
    private boolean fileContainsFieldDescription;
    private String csvFieldSeparator;
    private File csvFile;
    private String csvLineSeparator;
    private List columns = new ArrayList<>();
    private Action action;

    public CsvReader(File csvFile, String csvFieldSeparator, String csvLineSeparator, boolean fileContainsFieldDescription) {
        this.csvFile = csvFile;
        this.csvFieldSeparator = csvFieldSeparator;
        this.csvLineSeparator = csvLineSeparator;
        this.fileContainsFieldDescription = fileContainsFieldDescription;
    }

    public void process() {
        boolean firstLine = true;
        int nRead = 0;

        ArrayList lignesRestantes = new ArrayList<>();
        ArrayList colonnesRestantes = new ArrayList<>();
        ArrayList morceauxRestants = new ArrayList<>();


        String reste = "";

        try {
            FileInputStream fileInputStream = null;
            fileInputStream = new FileInputStream(csvFile);
            byte[] bytes = new byte[MAX_LINE_LENGTH_2];
            int countLines = 0;

            while ((nRead = fileInputStream.read(bytes)) > 0 /*|| reste.toString().length()>0*/) {
                if (countLines % countLineModulo == 0)
                    ;//Logger.getAnonymousLogger().log(Level.INFO, ""+countLines+" lignes traitées");
                String read = "";
                for (int i = 0; i < nRead; i++)
                    read += (char) (bytes[i]);
                read = "" + reste.toString() + read;
                reste = "";

                if (firstLine && fileContainsFieldDescription) {
                    String[] split0 = read.split(csvLineSeparator);
                    String[] split1 = split0[0].split(csvFieldSeparator);
                    for (int i = 0; i < split1.length; i++) {
                        columns.add(split1[i]);
                    }
                    firstLine = false;
                    // Traitement terminé.
                    // Reprendre ce qu'il reste pour la loop.
                    reste += split0[split0.length - 1];

                } else {
                    String[] split0 = read.split(csvLineSeparator);
                    for (int j = 0; j < split0.length - 1; j++) {
                        String[] split1 = split0[0].split(csvFieldSeparator);


                        // Traitement terminé. On passe à l'action
                        action.processLine(new CsvLine(columns, split1));
                        countLines++;
                    }
                    // Reprendre ce qu'il reste pour la loop.

                    reste += split0[split0.length - 1];
                }

            }
        } catch (IOException e) {
            e.printStackTrace();
        }


    }

    public int getMAX_LINE_LENGTH_2() {
        return MAX_LINE_LENGTH_2;
    }


    public boolean isFileContainsFieldDescription() {
        return fileContainsFieldDescription;
    }

    public void setFileContainsFieldDescription(boolean fileContainsFieldDescription) {
        this.fileContainsFieldDescription = fileContainsFieldDescription;
    }

    public String getCsvFieldSeparator() {
        return csvFieldSeparator;
    }

    public void setCsvFieldSeparator(String csvFieldSeparator) {
        this.csvFieldSeparator = csvFieldSeparator;
    }

    public File getCsvFile() {
        return csvFile;
    }

    public void setCsvFile(File csvFile) {
        this.csvFile = csvFile;
    }

    public String getCsvLineSeparator() {
        return csvLineSeparator;
    }

    public void setCsvLineSeparator(String csvLineSeparator) {
        this.csvLineSeparator = csvLineSeparator;
    }

    public List getColumns() {
        return columns;
    }

    public void setColumns(List columns) {
        this.columns = columns;
    }

    public Action getAction() {
        return action;
    }

    public void setAction(Action action) {
        this.action = action;
    }
}





© 2015 - 2025 Weber Informatics LLC | Privacy Policy