20 releases (7 breaking)

new 0.8.2 Apr 26, 2024
0.7.2 Apr 1, 2024
0.7.0 Mar 30, 2024

#1196 in Parser implementations

Download history 385/week @ 2024-02-19 189/week @ 2024-02-26 406/week @ 2024-03-04 248/week @ 2024-03-11 97/week @ 2024-03-18 194/week @ 2024-03-25 533/week @ 2024-04-01 107/week @ 2024-04-08 6/week @ 2024-04-15

864 downloads per month

MIT license

39KB
705 lines

html2md-rs

Parses HTML and converts it to markdown.

Usage

use html2md_rs::to_md::from_html_to_md;

fn main() {
    let html = "<h1>Hello, World!</h1>";
    let md = from_html_to_md(html);
    assert_eq!(md, "# Hello, World!");
}

Markdown Convention

There are many markdown conventions/standards out there. This project references the CommonMark Spec.

Supported HTML tags

Check the supported HTML tags here. Unsupported HTML tags will be parsed as NodeType::Unknown(String).

License

This project is licensed under the MIT License - see the LICENSE file for details.


lib.rs:

A library for safely parsing HTML and converting it to Markdown.

Example

use html2md_rs::to_md::from_html_to_md;

let html = "<h1>Hello World</h1>".to_string();
let parsed = from_html_to_md(html);

assert_eq!(parsed, "# Hello World\n");

Supported HTML Elements

The list of supported HTML elements is in the structs::NodeType enum.

HTML Attributes

By default, the library parses all attributes of an HTML element as a HashMap.

Markdown Convention

This library follows the CommonMark Spec.

License

This library is licensed under the MIT license. Check the GitHub repository for more information.

No runtime deps