gpt4 book ai didi

java - 一条记录多行,只有第一个带有 RID

转载 作者:行者123 更新时间:2023-12-01 11:41:32 28 4
gpt4 key购买 nike

我是刚开始使用 BeanIO 2.1,但又遇到了问题。

我正在尝试解码一个固定长度的文件,该文件有一些记录分布在几行上,其中“rid”仅标记在这些行的第一行上

示例:

:10:BLABLABLABLA
:11:/TRTP/SEPA OVERBOEKING/IBAN
HR W HERMAN
503270327C30,49NTRFSCT20111212
:12:BLABLABLABLA

如您所见,记录 ':11:' 分布在 3 行中。我想将这些行作为字符串列表来获取,其中将忽略“:11:”。

这是mapping.xml 文件:

<record name="ownerInformation" order="2" class="com.batch.records.OwnerInformation" minOccurs="1" maxOccurs="6" collection="list">
<field name="tag" type="string" length="4" rid="true" literal=":11:" ignore="true" />
<field name="description" type="string" length="unbounded" maxLength="65" />
</record>

结果出现UnexpectedRecordException异常:

org.beanio.UnexpectedRecordException: End of stream reached, expected record 'ownerInformation'

再次感谢您对我的帮助

最佳答案

可以Map Bean Objects that Span Multiple Records .

您必须为每一行创建记录 ID,例如:我使用命令来分隔字段。

11,/TRTP/SEPA OVERBOEKING/IBAN
12,HR W HERMAN
13,503270327C30
13,49NTRFSCT20111212

类似这样的:

<group name=ownerInfo class="com.batch.records.OwnerInformation" minOccurs="1" maxOccurs="6">
<record name="typeInfo" class="com.batch.records.Type" order="1" minOccurs="1" maxOccurs="1" >
<field name="recordType" rid="true" literal="11" ignore="true" />
<field name="iban" />
</record>
<record name="customer" class="com.batch.records.Customer" order="2" minOccurs="1" maxOccurs="1" >
<field name="recordType" rid="true" literal="12" ignore="true" />
<field name="name" />
</record>
<record name="items" class="com.batch.records.Item" collection="list" order="3" minOccurs="1" maxOccurs="unbounded" >
<field name="recordType" rid="true" literal="13" ignore="true" />
<field name="id" />
</record>
</group>

这将映射到 OwnerInformation,如下所示:

package com.batch.records;

/* Getters and Setter are omitted for brevity */

public class OwnerInformation {
Type type;
Customer customer;
List<Item> items;
}

public class Type {
String iban;
}

public class Customer {
String name;
}

public class Item {
String id;
}

关于java - 一条记录多行,只有第一个带有 RID,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29488810/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com