docx

Build Status docs.rs crates.io

A Rust library for parsing and generating docx files.

Create a new document

Use Docx::default to create a new empty Docx, then use Docx::write_file for saving it to a file.

```rust let mut docx = Docx::default(); let mut para = Para::default();

// create a new paragraph and insert it para.text("Lorem Ipsum"); docx.insert_para(para);

docx.write_file("demo.docx").unwrap(); ```

Also see: Docx::write.

Reading from files

Use DocxFile::from_file to extract content from docx files, then use DocxFile::parse to generate a Docx struct.

```rust let docx = DocxFile::from_file("origin.docx").unwrap(); let mut docx = docx.parse().unwrap(); let mut para = Para::default();

para.text("Lorem Ipsum"); docx.insert_para(para);

docx.writefile("originappended.docx").unwrap(); ```

To reduce allocations, DocxFile::parse returns a Docx struct contains references to DocxFile itself. It means you have to make sure that DocxFile lives as long as its returned Docx:

rust let mut docx_option = None; { let docx_file = DocxFile::from_file("foo.docx").unwrap(); let mut docx = docx_file.parse().unwrap(); docx_option = Some(docx); // `docx_file` gets dropped here and code fails to compile } docx_option.unwrap().write_file("foo.docx").unwrap();

Or you can use Docx::into_owned to convert it into Docx<'static>:

rust let mut docx_option = None; { let docx_file = DocxFile::from_file("foo.docx").unwrap(); let mut docx = docx_file.parse().unwrap(); docx_option = Some(docx.into_owned()); } docx_option.unwrap().write_file("foo.docx").unwrap();

Also see: DocxFile::from_reader.

License

MIT