2条回答 默认 最新
- w747770454 2017-08-10 02:22关注
已经找到解决办法。还是因为对API不熟造成的。avro 有方法能够解析无scheam的文件。前提是在类方法中指定一个scheam进行解析。
大致方法如下。
public static List getGenricRecordList(InputStream fin){List<GenericRecord> grList = new ArrayList<GenericRecord>(); /** 不指定类型 指定schema加载数据**/ DatumReader<GenericRecord> reader=new GenericDatumReader<GenericRecord>(SCHEMA$); Decoder decoder=DecoderFactory.get().binaryDecoder(fin,null); while(true){ try{ GenericRecord result=reader.read(null,decoder); grList.add(result); }catch(Exception e){ break; } } return grList; } 由于avro还未完全成熟,读文件到最后会抛出EOF异常。此时就是读到文件末尾了。每一个GenericRecord 是一行数据。使用实例result.get("")方法就可以获得指定内容。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 metadata提取的PDF元数据,如何转换为一个Excel
- ¥15 关于arduino编程toCharArray()函数的使用
- ¥100 vc++混合CEF采用CLR方式编译报错
- ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
- ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
- ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
- ¥50 如何openEuler 22.03上安装配置drbd
- ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
- ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
- ¥15 Windows11, backspace, enter, space键失灵