Metadata-Version: 2.1
Name: microformats
Version: 0.5.1
Summary: tools for microformats production, consumption and analysis
Home-page: https://ragt.ag/code/projects/python-microformats
License: BSD-3-Clause
Keywords: IndieWeb,microformats
Author: Angelo Gladding
Author-email: angelo@ragt.ag
Requires-Python: >=3.10,<3.11
Classifier: License :: OSI Approved :: BSD License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.10
Requires-Dist: beautifulsoup4 (>=4.11.2,<5.0.0)
Requires-Dist: easyuri (>=0.1.2)
Requires-Dist: mf2py (>=2.0.1,<3.0.0)
Requires-Dist: txtint (>=0.1.2)
Description-Content-Type: text/markdown
[microformats][0] are the simplest way to openly publish contacts, events,
reviews, recipes, and other structured information on the web.
>>> import mf
>>> url = "https://alice.example"
>>> doc = f'''
... <p class=h-card><a href={url}>Alice</a></p>
... <ul class=h-feed>
... <li class=h-entry>foo
... <li class=h-entry>bar
... </ul>
... '''
>>> page = mf.parse(doc=doc, url=url)
# TODO >>> dict(page)
# TODO >>> page.json
>>> card = page["items"][0]
>>> card["type"]
['h-card']
>>> card["properties"]
{'name': ['Alice'], 'url': ['https://alice.example']}
>>> feed = page["items"][1]
>>> feed["children"][0]["properties"]["name"]
['foo']
>>> mf.util.representative_card(page, url)
{'name': ['Alice'], 'url': ['https://alice.example']}
>>> mf.util.representative_feed(page, url)["items"][0]["name"]
['foo']
# TODO >>> page.representative_card
# TODO {'name': ['Alice'], 'url': ['https://alice.example']}
# TODO >>> page.representative_feed["items"][0]["name"]
# TODO ['foo']
Based upon [`mf2util`][1].
[0]: https://microformats.org/wiki/microformats
[1]: https://github.com/kylewm/mf2util