13

美しいスープ ドキュメントは、特定のタグ (それぞれリストとイテラブル) の子にアクセスするための属性 .contents と .children を提供し、ナビゲート可能な文字列とタグの両方を含みます。タイプ Tag の子のみが必要です。

私は現在、リスト内包表記を使用してこれを達成しています:

rows=[x for x in table.tbody.children if type(x)==bs4.element.Tag]

しかし、タグの子だけを取得するためのより良い/よりPythonic/組み込みの方法があるかどうか疑問に思っています。

4

1 に答える 1

16

JFSebastianのおかげで、以下が機能します。

rows=table.tbody.find_all(True, recursive=False)

ここのドキュメント:http ://www.crummy.com/software/BeautifulSoup/bs4/doc/#true

私の場合、テーブルに実際の行が必要だったので、最終的に次の行を使用しました。これはより正確で、より読みやすいと思います。

rows=table.tbody.find_all('tr')

繰り返しますが、ドキュメント:http ://www.crummy.com/software/BeautifulSoup/bs4/doc/#navigating-using-tag-names

これは、タグのすべての子を反復処理するよりも優れた方法だと思います。

次の入力で動作しました:

<table cellspacing="0" cellpadding="0">
  <thead>
    <tr class="title-row">
      <th class="title" colspan="100">
        <div style="position:relative;">
          President
            <span class="pct-rpt">
                99% reporting
            </span>
        </div>
      </th>
    </tr>
    <tr class="header-row">
        <th class="photo first">

        </th>
        <th class="candidate ">
          Candidate
        </th>
        <th class="party ">
          Party
        </th>
        <th class="votes ">
          Votes
        </th>
        <th class="pct ">
          Pct.
        </th>
        <th class="change ">
          Change from &lsquo;08
        </th>
        <th class="evotes last">
          Electoral Votes
        </th>
    </tr>
  </thead>
  <tbody>
      <tr class="">
          <td class="photo first">
            <div class="photo_wrap"><img alt="P-barack-obama" height="48" src="http://i1.nyt.com/projects/assets/election_2012/images/candidate_photos/election_night/p-barack-obama.jpg?1352320690" width="68" /></div>
          </td>
          <td class="candidate ">
            <div class="winner dem"><img alt="Hp-checkmark@2x" height="9" src="http://i1.nyt.com/projects/assets/election_2012/images/swatches/hp-checkmark@2x.png?1352320690" width="10" />Barack Obama</div>
          </td>
          <td class="party ">
            Dem.
          </td>
          <td class="votes ">
            2,916,811
          </td>
          <td class="pct ">
            57.3%
          </td>
          <td class="change ">
            -4.6%
          </td>
          <td class="evotes last">
            20
          </td>
      </tr>
      <tr class="">
          <td class="photo first">

          </td>
          <td class="candidate ">
            <div class="not-winner">Mitt Romney</div>
          </td>
          <td class="party ">
            Rep.
          </td>
          <td class="votes ">
            2,090,116
          </td>
          <td class="pct ">
            41.1%
          </td>
          <td class="change ">
            +4.3%
          </td>
          <td class="evotes last">
            0
          </td>
      </tr>
      <tr class="">
          <td class="photo first">

          </td>
          <td class="candidate ">
            <div class="not-winner">Gary Johnson</div>
          </td>
          <td class="party ">
            Lib.
          </td>
          <td class="votes ">
            54,798
          </td>
          <td class="pct ">
            1.1%
          </td>
          <td class="change ">
            &ndash;
          </td>
          <td class="evotes last">
            0
          </td>
      </tr>
      <tr class="last-row">
          <td class="photo first">

          </td>
          <td class="candidate ">
            div class="not-winner">Jill Stein</div>
          </td>
          <td class="party ">
            Green
          </td>
          <td class="votes ">
            29,336
          </td>
          <td class="pct ">
            0.6%
          </td>
          <td class="change ">
            &ndash;
          </td>
          <td class="evotes last">
            0
          </td>
      </tr>
      <tr>
        <td class="footer" colspan="100">
          <a href="/2012/results/president">President Map</a> &nbsp;|&nbsp;
          <a href="/2012/results/president/big-board">President Big Board</a>&nbsp;|&nbsp;
          <a href="/2012/results/president/exit-polls?state=il">Exit Polls</a>
        </td>
      </tr>
  </tbody>
</table>

于 2012-11-08T15:08:30.877 に答える