Simple mapping view to docx (Word Doc) elements
Project description
msword: local files Manager(s)
Simple mapping view to docx (Word Doc) elements
To install: pip install msword
- Installation
- Quick Start
- LocalDocxTextStore
- LocalDocxStore
- Package Architecture
- Mermaid Graphs
- License
Quick Start
For users who just want to extract text from a collection of local MS Word documents, the simplest approach is to use the LocalDocxTextStore. The following example demonstrates how to create a text store from a folder containing MS Word files and access the text content of a document:
from msword import LocalDocxTextStore
from msword.tests.util import test_data_dir # Directory with test data
# Create a text store that extracts and returns text from MS Word documents.
docs_text_content = LocalDocxTextStore(test_data_dir)
# List the available document keys (filtered to valid MS Word files).
print(sorted(docs_text_content))
# Access the text of a specific document.
print(docs_text_content['simple.docx'])
For users needing the full docx.Document objects for more advanced processing (e.g., modifying document structure, styling, etc.), use the LocalDocxStore:
from msword import LocalDocxStore
from msword.tests.util import test_data_dir
import docx
store = LocalDocxStore(test_data_dir)
doc = store['with_doc_extension.doc']
assert isinstance(doc, docx.document.Document)
print(doc.paragraphs[0].text)
LocalDocxTextStore
Local files store returning, as values, text extracted from the documents.
Use this when you just want the text contents of the document.
If you want more, you'll need to user LocalDocxStore with the appropriate content extractor
(i.e. the obj_of_data function in a dol.wrap_kvs wrapper).
Note: Filters for valid msword extensions (.doc and .docx).
To NOT filter for valid extensions, use AllLocalFilesDocxTextStore instead.
>>> from msword import LocalDocxTextStore, test_data_dir
>>> import docx
>>> s = LocalDocxTextStore(test_data_dir)
>>> assert {'with_doc_extension.doc', 'simple.docx'}.issubset(s)
>>> v = s['simple.docx']
>>> assert isinstance(v, str)
>>> print(v)
Just a bit of text to show that is works. Another sentence.
This is after a newline.
<BLANKLINE>
This is after two newlines.
LocalDocxStore
Local files store returning, as values, docx objects.
Note: Filters for valid msword extensions (.doc and .docx).
To Note filter for valid extensions, use AllLocalFilesDocxStore instead.
>>> from msword import LocalDocxStore, test_data_dir
>>> import docx
>>> s = LocalDocxStore(test_data_dir)
>>> assert {'with_doc_extension.doc', 'simple.docx'}.issubset(s)
>>> v = s['with_doc_extension.doc']
>>> assert isinstance(v, docx.document.Document)
What does a docx.document.Document have to offer?
If you really want to get into it, see here: https://python-docx.readthedocs.io/en/latest/
Meanwhile, we'll give a few examples here as an amuse-bouche.
>>> ddir = lambda x: set([xx for xx in dir(x) if not xx.startswith('_')]) # to see what an object has
>>> assert ddir(v).issuperset({
... 'add_heading', 'add_page_break', 'add_paragraph', 'add_picture', 'add_section', 'add_table',
... 'core_properties', 'element', 'inline_shapes', 'paragraphs', 'part',
... 'save', 'sections', 'settings', 'styles', 'tables'
... })
paragraphs is where the main content is, so let's have a look at what it has.
>>> len(v.paragraphs)
21
>>> paragraph = v.paragraphs[0]
>>> assert ddir(paragraph).issuperset({
... 'add_run', 'alignment', 'clear', 'insert_paragraph_before',
... 'paragraph_format', 'part', 'runs', 'style', 'text'
... })
>>> paragraph.text
'Section 1'
>>> assert ddir(paragraph.style).issuperset({
... 'base_style', 'builtin', 'delete', 'element', 'font', 'hidden', 'locked', 'name', 'next_paragraph_style',
... 'paragraph_format', 'part', 'priority', 'quick_style', 'style_id', 'type', 'unhide_when_used'
... })
>>> paragraph.style.style_id
'Heading1'
>>> paragraph.style.font.color.rgb
RGBColor(0x2f, 0x54, 0x96)
You get the point...
If you're only interested in one particular aspect of the documents, you should your favorite
dol wrappers to get the store you really want. For example:
>>> from dol import wrap_kvs
>>> ss = wrap_kvs(s, obj_of_data=lambda doc: [paragraph.style.style_id for paragraph in doc.paragraphs])
>>> assert ss['with_doc_extension.doc'] == [
... 'Heading1', 'Normal', 'Normal', 'Heading2', 'Normal', 'Normal',
... 'Heading1', 'Normal', 'Normal', 'Normal', 'Normal', 'Normal', 'Normal', 'Normal',
... 'ListParagraph', 'ListParagraph', 'Normal', 'Normal', 'ListParagraph', 'ListParagraph', 'Normal'
... ]
The most common use case is probably getting text, not styles, out of a document. It's so common, that we've done the wrapping for you: Just use the already wrapped LocalDocxTextStore store for that purpose.
Package Architecture
The module is built around a set of core classes and helper functions. Its functionality is entirely defined by the combination of a base file store (from dol.Files) and a set of decorators that wrap the store to transform its values.
Main Classes
-
AllLocalFilesDocxStore
A wrapper around a local file store that returns file contents asdocx.Documentobjects. This class does not filter file extensions, meaning that non-MS Word files might cause errors. -
AllLocalFilesDocxTextStore
Inherits fromAllLocalFilesDocxStoreand applies a text extraction function (get_text_from_docx). It returns the concatenated text of all paragraphs in the document. -
LocalDocxStore
ExtendsAllLocalFilesDocxStoreand uses theonly_files_with_msword_extensiondecorator to filter out files that do not have valid MS Word extensions (i.e.,.docor.docx). -
LocalDocxTextStore
ExtendsAllLocalFilesDocxTextStoreand applies the same file filtering asLocalDocxStore, ensuring that only valid MS Word files are processed.
Helper Functions
-
_extension(k: str)
Splits a filename and returns its extension. -
has_msword_extension(k: str)
Checks if a filename has a valid MS Word extension (docordocx). -
_remove_docx_extension(k: str) & _add_docx_extension(k: str)
Utilities to remove or add the default.docxextension to keys. -
paragraphs_text(doc)
Yields the text from each paragraph of adocx.Document. -
get_text_from_docx(doc, paragraph_sep='\n')
Concatenates all paragraph texts from a document using the specified separator. -
bytes_to_doc(doc_bytes: bytes)
Converts raw bytes into adocx.Documentusing an in-memory buffer.
Mapping Wrappers
-
with_bytes_to_doc_decoding
Wraps a mapping to convert byte values intodocx.Documentobjects. -
with_doc_to_text_decoding
Wraps a mapping to convertdocx.Documentobjects into text. -
with_bytes_to_text_decoding
Combines the two above by first converting bytes into a document and then extracting its text. -
only_files_with_msword_extension
Filters the keys of a store so that only those with valid MS Word extensions are processed.
Mermaid Graphs
Overall Object Relationships
flowchart TD
A[dol.Files]
B[AllLocalFilesDocxStore]
C[AllLocalFilesDocxTextStore]
D[LocalDocxStore]
E[LocalDocxTextStore]
A --> B
B --> C
B --> D
C --> E
subgraph Helper Functions
F[bytes_to_doc]
G[get_text_from_docx]
H[has_msword_extension]
I[only_files_with_msword_extension]
end
F --> B
G --> C
H --> I
I --> D
I --> E
Mapping Wrappers Pipeline
flowchart LR
RawBytes[Raw Bytes]
BytesToDoc[with_bytes_to_doc_decoding]
Doc[docx.Document]
DocToText[with_doc_to_text_decoding]
Text[get_text_from_docx]
BytesToText[with_bytes_to_text_decoding]
RawBytes --> BytesToDoc --> Doc
Doc --> DocToText --> Text
RawBytes --> BytesToText --> Text
License
This module is distributed under the terms of the MIT license.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file msword-0.0.7.tar.gz.
File metadata
- Download URL: msword-0.0.7.tar.gz
- Upload date:
- Size: 13.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.19
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
364127fd456de7ef842e7ce71bc5c53d7332f04a3e2d947bb6d22545d5e0ac95
|
|
| MD5 |
169546002ab02f50f26980402f1ed99f
|
|
| BLAKE2b-256 |
aa63c38133d7a4e8a22cd063623287571ce6a163d44aa5ae76afc738ea87109c
|
File details
Details for the file msword-0.0.7-py3-none-any.whl.
File metadata
- Download URL: msword-0.0.7-py3-none-any.whl
- Upload date:
- Size: 14.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.19
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9ad3722dc6e2ed5d6fd549d67ba60e2d7f33a5ce6e500f75ce4704c910824b28
|
|
| MD5 |
f523a8b6bb1f0cced1cd6c38e711b021
|
|
| BLAKE2b-256 |
8360dc6fbd252c8945950f8f4eab2f1e058e67abeec3f1fbcb98d5fc2c4379b7
|