JavaでXMLをSAXで解析する方法は?
カスタムデフォーハンドラーを作成し、解析イベントを処理するための起動、エンデレメント、キャラクター、その他の方法を書き直します。 2。saxparserfactoryを使用してsaxparserインスタンスを作成し、xmlファイルを解析のための解析方法を使用してカスタムプロセッサに関連付けます。 3。SAX解析は、イベント駆動型に基づいており、メモリの使用量が少なく、大きなファイルに適していますが、順番に読み取ることができ、XMLを変更できません。コンテキスト状態は、ネストされた構造を処理するために手動で維持する必要があります。解析プロセスは、StartDocumentからEndDocumentから始まります。
JavaのSAX(XMLのSimple API)でXMLを解析することは、ファイル全体をメモリにロードせずにドキュメントを順番に読み取るため、大規模なXMLファイルを処理するための高速かつメモリ効率の高い方法です。 SAXはイベント駆動型モデルを使用します。パーサーが要素、属性、テキストなどに遭遇すると、コールバックがトリガーされます。

JavaでSAXを使用してXMLを解析する方法は次のとおりです。
1.カスタムDefaultHandler
を作成します
org.xml.sax.helpers.DefaultHandler
を拡張し、解析イベントを処理するために重要な方法をオーバーライドする必要があります。

一般的にオーバーライドされた方法:
-
startElement()
- オープニングタグに遭遇したときに呼び出されます。 -
endElement()
- 閉鎖タグに遭遇したときに呼び出されます。 -
characters()
- タグ間でテキストコンテンツが求められます。 -
startDocument()
/endDocument()
- ドキュメントレベルのイベント用。
org.xml.sax.attributesをインポートします。 Import org.xml.sax.saxexception; Import org.xml.sax.helpers.defaulthandler; パブリッククラスmysaxhandlerはdefulthandlerを拡張します{ boolean isfirstname = false; boolean islastname = false; boolean isemail = false; @オーバーライド public void startelement(string uri、string localname、string qname、属性属性)saxexception { switch(qname.tolowercase()){ ケース「FirstName」: isfirstname = true; 壊す; ケース "lastname": ISLASTNAME = true; 壊す; ケース「電子メール」: iSemail = true; 壊す; } } @オーバーライド public void文字(char [] ch、int start、int length)はsaxexceptionをスローします{ string value = new String(ch、start、length).trim(); if(value.isempty())return; if(isfirstname){ System.out.println( "名:"値); isfirstname = false; } else if(islastname){ System.out.println( "姓:"値); islastName = false; } else if(isemail){ System.out.println( "email:" value); iSemail = false; } } @オーバーライド public void endelement(string uri、string localname、string qname)saxexception { //必要に応じてオプションのクリーンアップ } @オーバーライド public void startdocument()throws saxexception { System.out.println( "Parsing start ..."); } @オーバーライド public void enddocument()throws saxexception { system.out.println( "parsing ends。"); } }
SAXParserFactory
とSAXParser
を使用して、XMLを解析します
次に、 SAXParser
を使用してハンドラーを使用して、XMLファイルまたは入力ストリームを処理します。

javax.xml.parsers.saxparserをインポートします。 javax.xml.parsers.saxparserfactoryをインポートします。 java.io.fileをインポートします。 パブリッククラスのsaxparserexample { public static void main(string [] args){ 試す { // saxparserfactoryを作成します saxparserfactory Factory = saxparserfactory.newinstance(); // saxparserを作成します saxparser saxparser = factory.newsaxparser(); //ハンドラーを作成します mySaxhandler Handler = new MySaxHandler(); // XMLファイルを解析します ファイルinputFile = new File( "input.xml"); saxparser.parse(inputfile、handler); } catch(例外e){ e.printstacktrace(); } } }
3.サンプルXML(input.xml)
<?xmlバージョン= "1.0" encoding = "utf-8"?> <従業員> <従業員ID = "1"> <FirstName> John </firstName> <lastname> doe </lastname> <メール> john.doe@example.com </email> </従業員> <従業員ID = "2"> <FirstName> Jane </firstName> <lastname> smith </lastname> <メール> jane.smith@example.com </email> </従業員> </従業員>
出力:
解析が始まった... 名:ジョン 姓:doe メール:john.doe@example.com 名:ジェーン 姓:スミス メール:jane.smith@example.com 解析は終了しました。
覚えておくべき重要なポイント
- メモリ効率:SAXは、ドキュメント全体をメモリに保持していないため、大規模なXMLファイルに最適です。
- 読み取り専用:SAXは読むためだけです。 XMLを変更することはできません。
- イベントの順序は重要です:階層データが必要な場合は、コンテキストを手動で追跡する必要があります(たとえば、フラグやスタックを使用して)。
- ランダムアクセスはありません:特定の要素にジャンプすることはできません。つまり、順番にプロセスします。
ネストされた要素または複雑な構造の処理
複雑なXMLの場合、ハンドラーにスタックまたは現在のオブジェクト状態を維持します。たとえば、 startElement("employee")
が呼び出されたときにEmployee
オブジェクトを作成し、解析中にそれを入力し、 endElement("employee")
に到達したときに保存します。
それがJavaでのサックス解析の核心です。イベントベースのフローを理解すると、それは簡単です。基本的にハンドラーを実装し、パーサーに残りをさせます。
以上がJavaでXMLをSAXで解析する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undress AI Tool
脱衣画像を無料で

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

HashMapは、Javaのハッシュテーブルを介してキーと値のペアストレージを実装し、そのコアはデータの位置をすばやく配置することにあります。 1.最初にキーのHashCode()メソッドを使用して、ハッシュ値を生成し、ビット操作を介して配列インデックスに変換します。 2。異なるオブジェクトは、同じハッシュ値を生成し、競合をもたらす場合があります。この時点で、ノードはリンクされたリストの形式で取り付けられています。 JDK8の後、リンクされたリストが長すぎ(デフォルトの長さ8)、効率を改善するために赤と黒の木に変換されます。 3.カスタムクラスをキーとして使用する場合、equals()およびhashcode()メソッドを書き直す必要があります。 4。ハッシュマップは容量を動的に拡大します。要素の数が容量を超え、負荷係数(デフォルト0.75)を掛けた場合、拡張して再ハッシュします。 5。ハッシュマップはスレッドセーフではなく、マルチスレッドでconcuを使用する必要があります

オプションは、意図を明確に表現し、ヌルの判断のコードノイズを減らすことができます。 1. optional.ofnullableは、nullオブジェクトに対処する一般的な方法です。たとえば、マップから値を取得する場合、Orelseを使用してデフォルト値を提供できるため、ロジックはより明確かつ簡潔になります。 2.チェーンコールマップを使用してネストされた値を達成してNPEを安全に回避し、リンクが無効である場合はデフォルト値を返す場合は自動的に終了します。 3.フィルターは条件付きフィルタリングに使用でき、その後の操作は条件が満たされた場合にのみ実行され続けます。そうしないと、軽量のビジネス判断に適したOrelseに直接ジャンプします。 4.基本的なタイプや単純なロジックなど、複雑さを高めるなど、オプションを過剰使用することはお勧めしません。一部のシナリオはNUに直接戻ります。

java.io.notserializableExceptionに遭遇するためのコアワークアウンドは、シリアル化する必要があるすべてのクラスがシリアル化可能なインターフェイスを実装し、ネストされたオブジェクトのシリアル化サポートを確認することです。 1.メインクラスに機器を追加する可能性のあるものを追加します。 2.クラス内の対応するカスタムフィールドのクラスも、シリアル化可能なものを実装していることを確認します。 3.一時的に使用して、シリアル化する必要のないフィールドをマークする。 4.コレクションまたはネストされたオブジェクトの非シリアル化されたタイプを確認します。 5.どのクラスがインターフェイスを実装していないかを確認します。 6.キーデータの保存やシリアル化可能な中間構造の使用など、変更できないクラスの交換設計を検討します。 7.変更を検討してください

Javaのキャラクターエンコーディングの問題に対処するために、重要なのは、各ステップで使用されるエンコードを明確に指定することです。 1.テキストを読み書きするときは常にエンコードを指定し、inputstreamreaderとoutputStreamWriterを使用し、明示的な文字セットを渡して、システムのデフォルトエンコードに依存しないようにします。 2.ネットワーク境界で文字列を処理するときに両端が一貫していることを確認し、正しいコンテンツタイプのヘッダーを設定し、ライブラリでエンコードを明示的に指定します。 3. string.getBytes()およびNewString(byte [])を注意して使用し、プラットフォームの違いによって引き起こされるデータの破損を避けるために、常に手動でstardantcharsets.utf_8を指定します。要するに、

Javasocketプログラミングはネットワーク通信の基礎であり、クライアントとサーバー間のデータ交換はソケットを介して実現されます。 1。Javaのソケットは、クライアントが使用するソケットクラスとサーバーが使用するサーバーソケットクラスに分割されます。 2。ソケットプログラムを作成するときは、最初にサーバーリスニングポートを起動してから、クライアントによる接続を開始する必要があります。 3.コミュニケーションプロセスには、接続の確立、データの読み取りと書き込み、ストリームの閉鎖が含まれます。 4.注意事項には、ポート競合の避け、IPアドレスの正確な構成、合理的に閉じるリソース、複数のクライアントのサポートが含まれます。これらをマスターすると、基本的なネットワーク通信機能が実現できます。

Javaでは、Defaultのデフォルトソートルールを内部的に定義するためにAcparableが使用され、コンパレータを使用して複数のソートロジックを外部から定義します。 1.Comparableは、クラス自体によって実装されるインターフェイスです。比較()メソッドを書き換えることにより、自然な順序を定義します。弦や整数など、固定および最も一般的に使用されるソートメソッドを備えたクラスに適しています。 2。Comparatorは、同じクラスに複数の並べ替え方法が必要な状況に適した、Compare()メソッドを介して実装された外部定義の機能インターフェイスであり、クラスソースコードを変更できない、またはソートロジックが変更されることが多い場合があります。 2つの違いは、比較可能がソートロジックを定義するだけで、クラス自体を変更する必要があることですが、比較して

Javaにはマップを通過する3つの一般的な方法があります。1。エントリセットを使用してキーと値を同時に取得します。これは、ほとんどのシナリオに適しています。 2。キーセットまたは値をそれぞれキーまたは値を通過する。 3. Java8のForeachを使用して、コード構造を簡素化します。 EntrySetは、すべてのキー値ペアを含むセットを返し、各ループはキーと値に頻繁にアクセスするのに適したMap.entryオブジェクトを取得します。キーまたは値のみが必要な場合は、それぞれkeyset()またはvalues()を呼び出すことができます。または、キーを横断するときにmap.get(key)を介して値を取得できます。 Java 8はForeachを使用できます((key、value) - &gt

Injava、thestatickeywordmeansameansmestotheclassit self、nottointances.staticvariablesaresharedacrossallinstancesは、Objedcreationを使用して、GlobalTrackingorconconstants.StaticMethododsodsodsoperateateClasslevel
