1

これは私の問題です。BeanIO を使用して CSV を読み取る必要があります。この CSV は次のようなものです。

s1_el1;s1_el2;s1_el3;s1_el4;X1;Y1;Z1
s2_el1;s2_el2;s2_el3;s2_el4;X2;Y2;Z2
s2_el1;s2_el2;s2_el3;s2_el4;X3;Y3;Z3

sN_elM (N と M は行と列の増分値) をセクション (BeanIO セクション) に配置する必要があります。

私が実際に持っているのは、次のようなマッピング XML です。

<?xml version="1.0" encoding="UTF-8"?>
<beanio xmlns="http://www.beanio.org/2012/03" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.beanio.org/2012/03 http://www.beanio.org/2012/03/mapping.xsd">   
    <stream name="fileTabellaSconti" format="csv">      
        <parser>
            <property name="delimiter" value=";" />
            <property name="unquotedQuotesAllowed" value="true" />
            <property name="whitespaceAllowed" value="true" />
        </parser>       
        <record name="tabellaSconti" class="map">           
            <segment name="sconto" class="map" >
                <field name="categoria" />
                <field name="nome" />
                <field name="tipologia" />
                <field name="profilo" />
            </segment>          
            <field name="valoreSconto" type="java.lang.Integer" />
            <field name="codiceSts" />
            <field name="scontoEquivalente" type="java.lang.Integer" />         
        </record>       
    </stream>   
</beanio>

私の「writer()」関数では、これを行います:

public static void writer( File csv_file )
{
    factory.load(new File(user_dir+"/docroot/WEB-INF/src/it/saleshub/csv/mapping/map_sconto.xml"));

    BeanWriter out = factory.createWriter( "fileTabellaSconti", csv_file );

    int c = 0;
    while (c < 5)
    {
        c++;

        HashMap<String, Object> record = new HashMap<String, Object>();

        HashMap<String, Object> sconto = new HashMap<String, Object>();

        sconto.put( "categoria",        "cat_"+c );
        sconto.put( "nome",             "nome_"+c );
        sconto.put( "tipologia",        "tipologia_"+c );
        sconto.put( "profilo",          "profilo_"+c );

        record.put( "sconto" , sconto );

        record.put( "valoreSconto",     new Integer(c) );
        record.put( "codiceSts",        "sts_"+c );
        record.put( "scontoEquivalente",new Integer(c) );

        System.out.println(record);
        out.write(record);

    }

    out.flush();
    out.close();
}

しかし、この関数を使用するたびに、コードで次の例外が表示されます。

Bean identification failed: no record or group mapping for bean class 'class java.util.HashMap' [...]

私のエラーはどこですか?セグメントを間違った方法で使用していると思いますが、正しく使用する方法に関するドキュメントが見つかりません..

4

1 に答える 1

1

問題は、マッピングファイルとpojoクラスにあります。

マッピングファイルで定義されたすべてのフィールドには、セグメントまたはレコードのいずれかの親タグで定義されたクラスのセッターメソッドとゲッターメソッドが必要です。

ここでは、コードでpojoとして使用できないと思われるクラスマップを使用しました。また、セグメントでコレクションを使用する場合は、コレクション属性を使用して、マップまたはリストとして値を提供する必要があります。

    <record name="tabellaSconti" class="com.test.Parent">           
        <segment name="scontos" collection="list" class="com.test.Sconto" >
            <field name="categoria" />
            <field name="nome" />
            <field name="tipologia" />
            <field name="profilo" />
        </segment>
        <field name="valoreSconto" type="java.lang.Integer" />
        <field name="codiceSts" />
        <field name="scontoEquivalente" type="java.lang.Integer" />         
    </record> 

また、com.test.Parentでは、getScontosメソッドとsetScontosメソッドを、セグメント外のフィールドに対して他のgetterメソッドとsetterメソッドとともに定義する必要があります。また、Scontoクラスでは、セグメントで定義されたすべてのフィールドに対してgetterとsetterを定義する必要があります。

最後に、メインクラスのコードは次のようになります

    Parent record = new Parent;
    Sconto sconto = new Sconto();
    List<Sconto> scontos = new ArrayList<Sconto>();

    sconto.setCategoria("cat_"+c );
    sconto.setNome("nome_"+c );
    sconto.setTipologia("tipologia_"+c );
    sconto.setProfilo("profilo_"+c );

    scontos.add(sconto);

    record.setScontos(scontos);

    -------
    ---------
    out.write(record);
于 2013-03-02T18:46:24.883 に答える