0

現在、次のテキストファイルがあります。

1 Commercial & Enterprise  5   SLICE    59.99  IP MICRO 
2 Commercial & Enterprise  5   SLICE    59.99  MULTI-USE SWITCH
.
.
.
.
18 Government & Military   6   TCP      15.00  TCP 

次のように行を分割しようとしています。

Product number:  18
Category:        Government & Military
Product name:  TCP
Units in stock: 6
Price: $15.00
Total value: $90.00
Fee: $4.50
Total value: $94.50  

現在、次のコードがあります。

while ((line = lineReader.readLine()) != null) {

            StringTokenizer tokens = new StringTokenizer(line, "\t");

            p = new ActionProduct();
            add(p);
            String category = p.getCategory();
            String name = p.getName();
            category = tokens.nextToken();
            int item = p.getItem();
            double price = p.getPrice();
            int units = p.getUnits();

            while (tokens.hasMoreTokens()) {
            item = Integer.parseInt(tokens.nextToken());
            price = Double.parseDouble(tokens.nextToken());
            units = Integer.parseInt(tokens.nextToken());
            }

            System.out.println("Category: " + category);
            System.out.println("Product number:  " + item);
            System.out.println("Product name:  " + name);
            System.out.println("Units in stock: "+ units);
            System.out.println("Price: $" + String.format("%.2f", price)); 
            System.out.println("Total value: $" + String.format("%.2f",p.value()));
            System.out.println("Fee: $" + String.format("%.2f", p.fee()));

            System.out.println("Total value: $" + String.format("%.2f", value()));
        }

そして、代わりにこの出力を取得しています:

Category: 1 Commercial & Enterprise  5   SLICE    59.99  IP MICRO             
Product number:  0
Product name:  null
Units in stock: 0
Price: $0.00
Total value: $0.00
Fee: $0.00
Total value: $0.00
Category: 2 Commercial & Enterprise  5   SLICE    59.99  MULTI-USE SWITCH     
Product number:  0
Product name:  null
Units in stock: 0
Price: $0.00
Total value: $0.00
Fee: $0.00
Total value: $0.00

そこで私の質問は…テキスタイルの各値を個別に印刷できるように、ラインを分割するにはどうすればよいですか?? よろしくお願いします。

これが私のテキストファイルです:

1 Commercial & Enterprise  5   SLICE    59.99  IP MICRO             
2 Commercial & Enterprise  5   SLICE    59.99  MULTI-USE SWITCH     
3 Commercial & Enterprise  4   SLICE    59.99  2100                 
4 Commercial & Enterprise  6   SLICE    59.99  IP                   
5 Commercial & Enterprise  4   HDX      45.00  HYBRID CARRIER       
6 Commercial & Enterprise  10  TRANSip  45.00  IP Technology Suite  
7 Commercial & Enterprise  5   GUI      30.00  LINK COMMAND SYS     
8 Commercial & Enterprise  5   GUI      30.00  MAUI                 
9 Commercial & Enterprise  6   RCP      20.00  RCP                  
10 Government & Military   5   SLICE    60.00  IP MICRO             
11 Government & Military   5   SLICE    60.00  MULTI-USE SWITCH     
12 Government & Military   4   SLICE    60.00  2100                 
13 Government & Military   6   SLICE    55.00  IP                   
14 Government & Military   4   HDX.C    35.00  HYBRID CARRIER       
15 Government & Military   10  TRANSip  30.00  IP Technology Suite  
16 Government & Military   5   GUI      20.00  LINK COMMAND SYS     
17 Government & Military   5   GUI      20.00  MAUI                 
18 Government & Military   6   TCP      15.00  TCP  
4

2 に答える 2

1

任意のパターンに基づいてテキストを分割したいので、それがまさにRegEx の目的です。RegEx パーサーを使用して入力をトークン化し、必要に応じてトークンを処理します。

簡単に言えば、ファイルを読み取り、それを RegEx トークナイザーに渡してから、トークン (文字列) を処理します。

データの正規表現パターンの例は次のようになります

[0-9]+[\s]+[a-zA-Z\s\Q&\E]+[\s]+[0-9]+[\s]+[a-zA-Z]+[ \s]+[0-9\Q.\E]+[\s]+[a-zA-Z0-9]+

たとえば、次を使用して、パターンをすばやく効果的に作成できます。

http://gskinner.com/RegExr/

参考文献:

http://en.wikipedia.org/wiki/Regular_expression

http://docs.oracle.com/javase/tutorial/essential/regex/

http://docs.oracle.com/javase/1.4.2/docs/api/java/util/regex/Pattern.html

于 2012-03-31T20:07:41.807 に答える
1

データをよく見てください。より多くのデータを取得していますか、それともこれが唯一のファイルですか?

より多くのデータを取得している場合は、パーサーが引き続き機能することを確認できるように、何らかの仕様が必要です。

データの位置が固定されている場合は、次を使用できます

String part = line.substring(beginIndex, endIndex)

このデータファイルは、品番が増える場合を除いて、ほぼ固定位置です。

代わりに、正規表現または line.split(delimitor) で試すことができます

それらを本当に理解する前に、正規表現を使いすぎないでください。

これが唯一のファイルである場合、私は

String[] parts = line.split("  ") //two spaces

次に、取得した文字列配列から解析します。

最初のパーツ [0] には、製品番号とカテゴリの両方が含まれますが、分割することもできます。

于 2012-03-31T20:38:27.310 に答える