w3resource

Python BeautifulSoup: Find the siblings of tags in a given html document

BeautifulSoup: Exercise-24 with Solution

Write a Python program to find the siblings of tags in a given html document.

Sample Solution:

Python Code:

from bs4 import BeautifulSoup
html_doc = """
<html>
<head>
<meta http-equiv="Content-Type" content="text/html;
charset=iso-8859-1">
<title>An example of HTML page</title>
</head>
<body>
<h2>This is an example HTML page</h2>
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nunc at nisi velit,
aliquet iaculis est. Curabitur porttitor nisi vel lacus euismod egestas. In hac
habitasse platea dictumst. In sagittis magna eu odio interdum mollis. Phasellus
sagittis pulvinar facilisis. Donec vel odio volutpat tortor volutpat commodo.
Donec vehicula vulputate sem, vel iaculis urna molestie eget. Sed pellentesque
adipiscing tortor, at condimentum elit elementum sed. Mauris dignissim
elementum nunc, non elementum felis condimentum eu. In in turpis quis erat
imperdiet vulputate. Pellentesque mauris turpis, dignissim sed iaculis eu,
euismod eget ipsum. Vivamus mollis adipiscing viverra. Morbi at sem eget nisl
euismod porta.</p>
<p><a href="https://www.w3resource.com/html/HTML-tutorials.php">Learn HTML from
w3resource.com</a></p>
<p><a href="https://www.w3resource.com/css/CSS-tutorials.php">Learn CSS from 
w3resource.com</a></p>
<a class="sister" href="http://example.com/lacie" id="link1">Lacie</a>
<a class="sister" href="http://example.com/tillie"  id="link2">Tillie</a>
</body>
</html>
"""
soup = BeautifulSoup(html_doc,"lxml")
print("\nSiblings of tags:")
print(soup.select("#link1 ~ .sister"))
print(soup.select("#link1 + .sister"))

Sample Output:

Siblings of tags:
[<a class="sister" href="http://example.com/tillie" id="link2">Tillie</a>]
[<a class="sister" href="http://example.com/tillie" id="link2">Tillie</a>]

Python Code Editor:

Have another way to solve this solution? Contribute your code (and comments) through Disqus.

Previous: Write a Python program to find tag(s) directly beneath other tag(s) in a given html document.
Next: Write a Python program to find tags by CSS class in a given html document.

What is the difficulty level of this exercise?

Test your Programming skills with w3resource's quiz.



Become a Patron!

Follow us on Facebook and Twitter for latest update.

It will be nice if you may share this link in any developer community or anywhere else, from where other developers may find this content. Thanks.

https://w3resource.com/python-exercises/BeautifulSoup/python-beautifulsoup-exercise-24.php