ホームページ >バックエンド開発 >Python チュートリアル >私の美しいスープ `ResultSet` オブジェクトに `find_all` 属性がないのはなぜですか?
Beautiful Soup: 'ResultSet' オブジェクトの欠落している 'find_all' 属性の解決
Beautiful Soup を使用して HTML または XML からデータを取得する場合ドキュメントを作成すると、「「ResultSet」オブジェクトには属性がありません」というメッセージを含む「AttributeError」が発生する場合があります。 「すべて検索」。このエラーは、「ResultSet」オブジェクト自体に対して「find_all」メソッドを使用しようとしたときによく発生しますが、これはよくある誤解です。
この問題を理解するには、「ResultSet」オブジェクトと個別のオブジェクトを区別することが重要です。そのセット内の要素。 「ResultSet」には類似した要素のコレクションが含まれますが、各要素自体は「タグ」です。指定したコードでは、「table」変数は、Web ページのテーブル要素を含む「ResultSet」を保持します。
コード内でテーブル行 (「tr」要素) を取得するには、次のアクセスが必要です。インデックスを使用して「ResultSet」内の個々の要素を取得します。次のコードはテーブル行を正しく取得します:
for row in table[0].find_all('tr'): col = table[0].find_all('td') # Get table data columns (within the current row)
ここで、'table[0]' は具体的に 'ResultSet' 内の最初のテーブル要素 (Web ページ上の 'table' 要素) にアクセスします。 。次に、この要素に対して 'find_all' メソッドを使用して、その要素に含まれる 'tr' 要素 (テーブル行) を取得できます。
'ResultSet' 内の個々の要素に適切にアクセスすることで、' find_all' メソッドを使用して、HTML ドキュメントから必要なデータを抽出します。
以上が私の美しいスープ `ResultSet` オブジェクトに `find_all` 属性がないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。