当前位置: 首页>>代码示例>>Java>>正文


Java CsvParser.parseNext方法代码示例

本文整理汇总了Java中com.univocity.parsers.csv.CsvParser.parseNext方法的典型用法代码示例。如果您正苦于以下问题:Java CsvParser.parseNext方法的具体用法?Java CsvParser.parseNext怎么用?Java CsvParser.parseNext使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在com.univocity.parsers.csv.CsvParser的用法示例。


在下文中一共展示了CsvParser.parseNext方法的7个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: readStream

import com.univocity.parsers.csv.CsvParser; //导入方法依赖的package包/类
/**
 * Read stream of taxi trip data from file
 * and broadcast its value next.
 *
 * @throws InterruptedException
 */
public void readStream() throws InterruptedException {
    // setting up CSV parser
    CsvParser parser = setupParser();

    // read records one by one
    parser.beginParsing(getReader(this.fileName));

    String[] row;
    // read line by line
    while ((row = parser.parseNext()) != null) {
        // create a string from array separated by comma
        String trip = String.join(",", row);

        // sink values to trips broadcaster
        this.tripsProcessor.onNext(trip);
    }
    // close the channel as we are finished streaming data
    // this sends a complete signal which we can in turn observe
    this.tripsProcessor.onComplete();

    // finished parsing all the data from the csv file
    parser.stopParsing();
}
 
开发者ID:jeryini,项目名称:TaxiManagementSystem,代码行数:30,代码来源:TaxiStream.java

示例2: processSinglePathWithByteBuffer

import com.univocity.parsers.csv.CsvParser; //导入方法依赖的package包/类
private void processSinglePathWithByteBuffer(BatchWriter writer, FileMapping mapping, Path p, CsvParser parser) throws IOException, MutationsRejectedException {
  final FileSystem fs = p.getFileSystem(conf);
  FSDataInputStream dis = fs.open(p, INPUT_BUFFER_SIZE);
  InputStreamReader reader = new InputStreamReader(dis, UTF_8);
  try {
    parser.beginParsing(reader);
    String[] line = null;
    while ((line = parser.parseNext()) != null) {
      writer.addMutation(parseLine(mapping, line));
    }
  } finally {
    if (null != reader) {
      reader.close();
    }
  }
}
 
开发者ID:joshelser,项目名称:accumulo-delimited-ingest,代码行数:17,代码来源:DelimitedIngest.java

示例3: init

import com.univocity.parsers.csv.CsvParser; //导入方法依赖的package包/类
@Before
public void init() {
	parser = new CsvParser(settings);
	parser.beginParsing(new StringReader(CSV));
	rowContext = PowerMockito.spy(new UnivocityParserRowContext(parser.getContext(), metadata.size()));
	parser.parseNext();
}
 
开发者ID:axibase,项目名称:atsd-jdbc,代码行数:8,代码来源:UnivocityParserRowContextTest.java

示例4: parseDataset

import com.univocity.parsers.csv.CsvParser; //导入方法依赖的package包/类
public List<BlockWithData> parseDataset(String pathToFile) {
    List<BlockWithData> blocksWithData = new ArrayList<>();
    CsvParser parser = dataParser.getParserForFile(pathToFile);
    String[] fields = parser.parseNext();

    if (fields != null) {
        List<String> fieldsNames = new ArrayList<>(Arrays.asList(fields));
        blocksWithData = blockBuilder.build(parser, fieldsNames);
    }
    return blocksWithData;
}
 
开发者ID:sapirgolan,项目名称:MFIBlocking,代码行数:12,代码来源:ParsingService.java

示例5: build

import com.univocity.parsers.csv.CsvParser; //导入方法依赖的package包/类
@Override
public List<BlockWithData> build(CsvParser parser, List<String> fieldsNames) {
    this.fieldsNames = fieldsNames;

    List<BlockWithData> blocksWithData = new ArrayList<>();
    List<Record> recordsForBlock = new ArrayList<>();
    String[] row = parser.parseNext();
    String currentBlockId;
    //while there are more rows in dataset
    currentBlockId = initForFirstRecordOnly(row, recordsForBlock);
    row = parser.parseNext();
    // we have already initialized the first record, therefore the index starts at 2
    int recordIndex = STARTING_RECORD_INDEX;
    while (row != null && currentBlockId != null) {
        Record record = this.createRecord(row, recordIndex);

        String blockId = getBlockIdFromRecord(record);
        if (blockId.equals(currentBlockId)) {
            recordsForBlock.add(record);
        } else {
            createBlockFromRecords(blocksWithData, recordsForBlock);
            recordsForBlock = new ArrayList<>();
            recordsForBlock.add(record);
            currentBlockId = blockId;
        }
        row = parser.parseNext();
        recordIndex++;
    }
    if (!recordsForBlock.isEmpty()) {
        createBlockFromRecords(blocksWithData, recordsForBlock);
    }

    return blocksWithData;
}
 
开发者ID:sapirgolan,项目名称:MFIBlocking,代码行数:35,代码来源:FebrlBlockBuilder.java

示例6: end

import com.univocity.parsers.csv.CsvParser; //导入方法依赖的package包/类
@Override
public void end(byte packID)
{
    isStartLoadData = false;
    this.packID = packID;
    //load in data空包 结束
    saveByteOrToFile(null, true);
    List<SQLExpr> columns = statement.getColumns();
    String tableName = statement.getTableName().getSimpleName();
    if (isHasStoreToFile)
    {
        parseFileByLine(tempFile, loadData.getCharset(), loadData.getLineTerminatedBy());
    } else
    {
        String content = new String(tempByteBuffer.toByteArray(), Charset.forName(loadData.getCharset()));

        // List<String> lines = Splitter.on(loadData.getLineTerminatedBy()).omitEmptyStrings().splitToList(content);
        CsvParserSettings settings = new CsvParserSettings();
        settings.setMaxColumns(65535);
        settings.setMaxCharsPerColumn(65535);
        settings.getFormat().setLineSeparator(loadData.getLineTerminatedBy());
        settings.getFormat().setDelimiter(loadData.getFieldTerminatedBy().charAt(0));
        if(loadData.getEnclose()!=null)
        {
            settings.getFormat().setQuote(loadData.getEnclose().charAt(0));
        }
        if(loadData.getEscape()!=null)
        {
        settings.getFormat().setQuoteEscape(loadData.getEscape().charAt(0));
        }
        settings.getFormat().setNormalizedNewline(loadData.getLineTerminatedBy().charAt(0));
        /*
         *  fix bug #1074 : LOAD DATA local INFILE导入的所有Boolean类型全部变成了false
         *  不可见字符将在CsvParser被当成whitespace过滤掉, 使用settings.trimValues(false)来避免被过滤掉
         *  TODO : 设置trimValues(false)之后, 会引起字段值前后的空白字符无法被过滤!
         */
        settings.trimValues(false);
        CsvParser parser = new CsvParser(settings);
        try
        {
            parser.beginParsing(new StringReader(content));
            String[] row = null;

            while ((row = parser.parseNext()) != null)
            {
                parseOneLine(columns, tableName, row, false, null);
            }
        } finally
        {
            parser.stopParsing();
        }


    }

    RouteResultset rrs = buildResultSet(routeResultMap);
    if (rrs != null)
    {
        flushDataToFile();
        serverConnection.getSession2().execute(rrs, ServerParse.LOAD_DATA_INFILE_SQL);
    }


    // sendOk(++packID);


}
 
开发者ID:huang-up,项目名称:mycat-src-1.6.1-RELEASE,代码行数:68,代码来源:ServerLoadDataInfileHandler.java

示例7: end

import com.univocity.parsers.csv.CsvParser; //导入方法依赖的package包/类
@Override
public void end(byte packId) {
    isStartLoadData = false;
    this.packID = packId;
    //empty packet for end
    saveByteOrToFile(null, true);

    List<SQLExpr> columns = statement.getColumns();
    String tableSimpleName = statement.getTableName().getSimpleName();
    if (isHasStoreToFile) {
        parseFileByLine(tempFile, loadData.getCharset(), loadData.getLineTerminatedBy());
    } else {
        String content = new String(tempByteBuffer.toByteArray(), Charset.forName(loadData.getCharset()));

        // List<String> lines = Splitter.on(loadData.getLineTerminatedBy()).omitEmptyStrings().splitToList(content);
        CsvParserSettings settings = new CsvParserSettings();
        settings.setMaxColumns(65535);
        settings.setMaxCharsPerColumn(65535);
        settings.getFormat().setLineSeparator(loadData.getLineTerminatedBy());
        settings.getFormat().setDelimiter(loadData.getFieldTerminatedBy().charAt(0));
        if (loadData.getEnclose() != null) {
            settings.getFormat().setQuote(loadData.getEnclose().charAt(0));
        }
        if (loadData.getEscape() != null) {
            settings.getFormat().setQuoteEscape(loadData.getEscape().charAt(0));
        }
        settings.getFormat().setNormalizedNewline(loadData.getLineTerminatedBy().charAt(0));
        /*
         *  fix bug #1074 : LOAD DATA local INFILE导入的所有Boolean类型全部变成了false
         *  不可见字符将在CsvParser被当成whitespace过滤掉, 使用settings.trimValues(false)来避免被过滤掉
         *  FIXME : 设置trimValues(false)之后, 会引起字段值前后的空白字符无法被过滤!
         */
        settings.trimValues(false);

        CsvParser parser = new CsvParser(settings);
        try {
            parser.beginParsing(new StringReader(content));
            String[] row = null;

            int ignoreNumber = 0;
            if (statement.getIgnoreLinesNumber() != null && !"".equals(statement.getIgnoreLinesNumber().toString())) {
                ignoreNumber = Integer.parseInt(statement.getIgnoreLinesNumber().toString());
            }
            while ((row = parser.parseNext()) != null) {
                if (ignoreNumber == 0) {
                    parseOneLine(columns, tableSimpleName, row, true, loadData.getLineTerminatedBy());
                } else {
                    ignoreNumber--;
                }
            }
        } finally {
            parser.stopParsing();
        }
    }

    RouteResultset rrs = buildResultSet(routeResultMap);
    if (rrs != null) {
        flushDataToFile();
        serverConnection.getSession2().execute(rrs);
    }

    // sendOk(++packID);
}
 
开发者ID:actiontech,项目名称:dble,代码行数:64,代码来源:ServerLoadDataInfileHandler.java


注:本文中的com.univocity.parsers.csv.CsvParser.parseNext方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。