ssc_codegen - generator of parsers for various programming languages (for html priority) using python-DSL configurations with built-in declarative language.
Designed to port parsers to various programming languages and libs
interesting in practice write DSL-like language- decrease boilerplate code for web-parsers
- write once - convert to other mainstream http parser libs
- minimal operations for easy add another libs and languages in future
- include css, xpath, attributes operations, regex, minimal string formatting operations
- pre validate css/xpath queries and logic before generate code
- standardisation: generate classes with minimal dependencies and documented parsed signature
pipx install ssc_codegen
pip install ssc_codegen
language | lib | xpath | css | formatter |
---|---|---|---|---|
python | bs4 | NO | YES | black |
- | parsel | YES | YES | - |
- | selectolax (modest) | NO | YES | - |
- | scrapy (based on parsel, but class init argument - Response) | YES | YES | - |
dart | universal_html | NO | YES | dart format |
see example and read code with comments
- usage css selector: they can be guaranteed converted to xpath (if target language not support CSS selectors)
- usage simple operations for more compatibility other libraries.
- Some libraries may not fully support selector specifications
- for example,
#product_description+ p
selector inparsel
works fine, but not works inselectolax
,dart
libs
- there is a xpath to css converter for simple queries without guarantees of functionality.
For example, in css there is no analogue of
contains
from xpath, etc.