QXmlSimpleReader Class

QXmlSimpleReader クラスは、シンプルな XML パーサーの実装を提供します。詳細...

Header: #include <QXmlSimpleReader>
CMake: find_package(Qt6 REQUIRED COMPONENTS Core5Compat)
target_link_libraries(mytarget PRIVATE Qt6::Core5Compat)
qmake: QT += core5compat
Inherits: QXmlReader

警告このクラスはリエントラントではありません。

パブリック関数

QXmlSimpleReader()
virtual ~QXmlSimpleReader()
virtual bool parse(const QXmlInputSource *input, bool incremental)
virtual bool parseContinue()

再実装パブリック関数

virtual QXmlDTDHandler *DTDHandler() const override
virtual QXmlContentHandler *contentHandler() const override
virtual QXmlDeclHandler *declHandler() const override
virtual QXmlEntityResolver *entityResolver() const override
virtual QXmlErrorHandler *errorHandler() const override
virtual bool feature(const QString &name, bool *ok = nullptr) const override
virtual bool hasFeature(const QString &name) const override
virtual bool hasProperty(const QString &name) const override
virtual QXmlLexicalHandler *lexicalHandler() const override
virtual bool parse(const QXmlInputSource &input) override
virtual bool parse(const QXmlInputSource *input) override
virtual void *property(const QString &name, bool *ok = nullptr) const override
virtual void setContentHandler(QXmlContentHandler *handler) override
virtual void setDTDHandler(QXmlDTDHandler *handler) override
virtual void setDeclHandler(QXmlDeclHandler *handler) override
virtual void setEntityResolver(QXmlEntityResolver *handler) override
virtual void setErrorHandler(QXmlErrorHandler *handler) override
virtual void setFeature(const QString &name, bool enable) override
virtual void setLexicalHandler(QXmlLexicalHandler *handler) override
virtual void setProperty(const QString &name, void *value) override

詳細説明

このXMLリーダは幅広いアプリケーションに適している。整形式のXMLを解析することができ、要素の名前空間をコンテンツハンドラに報告することができる。歴史的な理由により、XML 1.0仕様に記述されている属性値の正規化と行末処理は行われない。

このクラスの最も簡単な使用パターンは、リーダーのインスタンスを作成し、入力ソースを定義し、リーダーによって使用されるハンドラを指定し、データを解析することです。

例えば、QFile を使って入力を供給することができる。ここでは、リーダーを作成し、リーダーが使用する入力ソースを定義する:

    QXmlSimpleReader xmlReader;
    QXmlInputSource *source = new QXmlInputSource(file);

ハンドラーは、リーダーが特定のタイプのコンテンツに遭遇したときや、入力にエラーが見つかったときに、アクションを実行するためのものである。ハンドラーは、リーダーが特定の種類のコンテンツに遭遇したときや、入力にエラーが見つかったときにアクションを実行するものである。リーダーには、イベントの種類ごとにどのハンドラーを使用するかを指示しなければならない。多くの一般的なアプリケーションでは、QXmlDefaultHandler をサブクラス化することで、カスタム・ハンドラを作成することができます:

    Handler *handler = new Handler;
    xmlReader.setContentHandler(handler);
    xmlReader.setErrorHandler(handler);

少なくともコンテンツとエラーのハンドラを設定しないと、パーサーはデフォルトの動作に戻り、何もしなくなります。

入力を処理する最も便利な方法は、入力ソースを指定する引数を持つparse() 関数を使用して、入力を一度に読み込むことです:

    bool ok = xmlReader.parse(source);

    if (!ok)
        std::cout << "Parsing failed." << std::endl;

入力全体を一度に解析できない場合(例えば、入力が巨大であったり、ネットワーク接続を介して配信される場合など)、データを分割してパーサーに供給することができる。これは、parse ()にインクリメンタルに処理するように指示し、すべてのデータが処理されるまで、parseContinue ()関数を呼び出すことで実現できる。

インクリメンタル・パーシングを実行する一般的な方法は、network replyreadyRead() シグナルをスロットに接続し、そこで入力データを処理することである。QNetworkAccessManager を参照のこと。

構文解析の動作は、setFeature() やsetProperty() を使用して変更できます。

xmlReader.setFeature("http://xml.org/sax/features/namespace-prefixes", true);

QXmlSimpleReader は再入可能ではありません。スレッド化されたコードでこのクラスを使用する場合は、QMutex などのロック機構で QXmlSimpleReader を使用するコードをロックしてください。

このクラスは現在非推奨であることに注意してください。XMLファイルの読み取りには、QXmlStreamReader または QDomDocument を使用してください。

メンバ関数 ドキュメント

QXmlSimpleReader::QXmlSimpleReader()

単純な XML リーダーを構築します。

[virtual noexcept] QXmlSimpleReader::~QXmlSimpleReader()

単純な XML リーダーを破棄します。

[override virtual] QXmlDTDHandler *QXmlSimpleReader::DTDHandler() const

再インプリメント:QXmlReader::DTDHandler() const.

setDTDHandler()も参照

[override virtual] QXmlContentHandler *QXmlSimpleReader::contentHandler() const

再インプリメント:QXmlReader::contentHandler() const.

setContentHandler()も参照

[override virtual] QXmlDeclHandler *QXmlSimpleReader::declHandler() const

再インプリメント:QXmlReader::declHandler() const.

setDeclHandler()も参照

[override virtual] QXmlEntityResolver *QXmlSimpleReader::entityResolver() const

再インプリメント:QXmlReader::entityResolver() const.

setEntityResolver()も参照

[override virtual] QXmlErrorHandler *QXmlSimpleReader::errorHandler() const

再インプリメント:QXmlReader::errorHandler() const.

setErrorHandler()も参照

[override virtual] bool QXmlSimpleReader::feature(const QString &name, bool *ok = nullptr) const

再実装:QXmlReader::feature(const QString &name, bool *ok) const.

setFeature()も参照して ください。

[override virtual] bool QXmlSimpleReader::hasFeature(const QString &name) const

再インプリメント:QXmlReader::hasFeature(const QString &name) const.

[override virtual] bool QXmlSimpleReader::hasProperty(const QString &name) const

再実装: (const QString &name) const:QXmlReader::hasProperty(const QString &name) const.

[override virtual] QXmlLexicalHandler *QXmlSimpleReader::lexicalHandler() const

再実装:QXmlReader::lexicalHandler() const.

setLexicalHandler()も参照してください

[override virtual] bool QXmlSimpleReader::parse(const QXmlInputSource &input)

再実装:QXmlReader::parse(const QXmlInputSource &input).

[override virtual] bool QXmlSimpleReader::parse(const QXmlInputSource *input)

再リンプルメント: (const QXmlInputSource &input):QXmlReader::parse(const QXmlInputSource *input)。

input から XML ドキュメントを読み込み、1 回で (非インクリメントで) パースします。パースに成功した場合はtrue を返し、失敗した場合はfalse を返します。

[virtual] bool QXmlSimpleReader::parse(const QXmlInputSource *input, bool incremental)

input から XML ドキュメントを読み込み、それを解析する。構文解析が正常に完了した場合はtrue を返し、そうでない場合はエラーが発生したことを示すfalse を返す。

incremental が false の場合、XML ファイルが完全に読み込まれないと、この関数は false を返す。この場合、構文解析を続行することはできない。

incremental が真の場合、パーサーは、XML ファイルの終端に到達する前にinput の終端に到達しても、false を返さない。その代わり、パーサーの状態を保存し、後でデータが増えたときに構文解析を続行できるようにします。このような場合、parseContinue() 関数を使用して構文解析を続行できます。このクラスは入力ソースinput へのポインタを格納し、parseContinue() 関数はその入力ソースからの読み取りを試みます。したがって、parseContinue() を呼び出す必要がなくなるまで、入力ソースinput を削除しないでください。

インクリメンタル解析中にincremental を true に設定してこの関数を呼び出すと、新しい解析セッ ションが開始され、前のセッションは失われます。

parseContinue() およびQTcpSocketも参照のこと

[virtual] bool QXmlSimpleReader::parseContinue()

parse() の直近の呼び出しで指定されたQXmlInputSource からの入力を受けて、インクリメンタル構文解析を続行する。この関数を使用するには、parse() の incremental 引数を true に設定して呼び出す必要があります

解析エラーが発生した場合はfalse を返し、そうでない場合は XML ファイルの終端に達していなくてもtrue を返します。解析できるデータが増えたときにこの関数を再度呼び出すことで、後の段階で解析を続行できます。

入力ソースに利用可能なデータがないときにこの関数を呼び出すと、XML ファイルの終端に達したことを読 み手に示します。この時点までに供給された入力が整形式でなかった場合、構文解析エラーが発生し、falseが返されます。与えられた入力が整形式であった場合、trueが返される。このように入力を終了させることは重要です。なぜなら、他のXMLファイルを解析するためにリーダを再利用することができるからです。

ファイルの終端に達した後で、利用可能なデータがない状態でこの関数を呼び出すと、前の入力が整形式であったかどうかにかかわらず、falseが返されます。

parse(),QXmlInputSource::data(),QXmlInputSource::next()も参照

[override virtual] void *QXmlSimpleReader::property(const QString &name, bool *ok = nullptr) const

再実装:QXmlReader::property(const QString &name, bool *ok) const.

setProperty()も参照

[override virtual] void QXmlSimpleReader::setContentHandler(QXmlContentHandler *handler)

再実装:QXmlReader::setContentHandler(QXmlContentHandler *handler) const.

contentHandler()も参照して ください。

[override virtual] void QXmlSimpleReader::setDTDHandler(QXmlDTDHandler *handler)

再定義します:QXmlReader::setDTDHandler(QXmlDTDHandler *handler).

[override virtual] void QXmlSimpleReader::setDeclHandler(QXmlDeclHandler *handler)

再リンプルメント: (QXmlDeclHandler *handler):QXmlReader::setDeclHandler(QXmlDeclHandler *handler)。

declHandler()も参照してください

[override virtual] void QXmlSimpleReader::setEntityResolver(QXmlEntityResolver *handler)

再実装:QXmlReader::setEntityResolver(QXmlEntityResolver *handler).

entityResolver() も参照して ください。

[override virtual] void QXmlSimpleReader::setErrorHandler(QXmlErrorHandler *handler)

再リンプルメント:QXmlReader::setErrorHandler(QXmlErrorHandler *handler).

errorHandler() も参照して ください。

[override virtual] void QXmlSimpleReader::setFeature(const QString &name, bool enable)

再実装:QXmlReader::setFeature(const QString &name, bool value)。

enable が true の場合、name をオンにし、それ以外の場合はオフにします。

name パラメータは以下の文字列のいずれかでなければならない:

機能デフォルト備考
http://xml.org/sax/features/namespacestrue有効にすると、名前空間がコンテンツハンドラに報告されます。
http://xml.org/sax/features/namespace-prefixesfalse有効にすると、名前空間宣言に使われる元の接頭辞付き名と属性が報告されます。
http://qt-project.org/xml/features/report-whitespace-only-CharDatatrue有効にすると、空白文字のみで構成される CharData はQXmlContentHandler::characters() を使って報告されます。無効にすると、空白文字は黙って破棄されます。
http://qt-project.org/xml/features/report-start-end-entityfalse有効な場合、パーサーは QXmlContentHandler::startEntity() および QXmlContentHandler::endEntity() イベントを報告します。無効にすると、パーサーはこれらのイベントを報告せず、エンティティを無言で置換し、文字データを1つのチャンクで報告します。

feature() およびhasFeature()も参照

[override virtual] void QXmlSimpleReader::setLexicalHandler(QXmlLexicalHandler *handler)

再実装:QXmlReader::setLexicalHandler(QXmlLexicalHandler *handler)。

lexicalHandler() も参照

[override virtual] void QXmlSimpleReader::setProperty(const QString &name, void *value)

再実装:QXmlReader::setProperty(const QString &name, void *value)。

property() も参照して ください。

©2024 The Qt Company Ltd. 本文書に含まれる文書の著作権は、それぞれの所有者に帰属します。 本書で提供されるドキュメントは、Free Software Foundation が発行したGNU Free Documentation License version 1.3に基づいてライセンスされています。 Qtおよびそれぞれのロゴは、フィンランドおよびその他の国におけるThe Qt Company Ltd.の 商標です。その他すべての商標は、それぞれの所有者に帰属します。