2023-06-05 11:27:12 -07:00
|
|
|
import os
|
|
|
|
import pathlib
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
|
2023-09-11 16:00:14 -05:00
|
|
|
from unstructured.chunking.title import chunk_by_title
|
feat: `partition_xml` infers element type on each leaf node (#1249)
### Summary
Closes #1229. Updates `partition_xml` so that the element type is
inferred on each leaf node when `xml_keep_tags=False` instead of
delegating splitting and partitioning to `partition_xml`. If
`xml_keep_tags=True`, the file is treated like a text file still and
partitioning is still delegated to `partition_text`.
Also adds the option to pass `text` as an input to `partition_xml`.
### Testing
Create a `parrots.xml` file that looks like:
```xml
<xml><parrot><name>Conure</name><description>A conure is a very friendly bird.
Conures are feathery and like to dance.</description></parrot></xml>
```
Run:
```python
from unstructured.partition.xml import partition_xml
from unstructured.staging.base import convert_to_dict
elements = partition_xml(filename="parrots.xml")
convert_to_dict(elements)
```
One `main`, the output is the following. Notice how the `<name>` tag
incorrectly gets merged into `<description>` in the first element.
```python
[{'element_id': '7ae4074435df8dfcefcf24a4e6c52026',
'metadata': {'file_directory': '/home/matt/tmp',
'filename': 'parrots.xml',
'filetype': 'application/xml',
'last_modified': '2023-08-30T14:21:38'},
'text': 'Conure A conure is a very friendly bird.',
'type': 'NarrativeText'},
{'element_id': '859ecb332da6961acd2fb6a0185d1549',
'metadata': {'file_directory': '/home/matt/tmp',
'filename': 'parrots.xml',
'filetype': 'application/xml',
'last_modified': '2023-08-30T14:21:38'},
'text': 'Conures are feathery and like to dance.',
'type': 'NarrativeText'}]
```
One the feature branch, the output is the following, and the tags are
correctly separated.
```python
[{'element_id': '5512218914e4eeacf71a9cd42c373710',
'metadata': {'file_directory': '/home/matt/tmp',
'filename': 'parrots.xml',
'filetype': 'application/xml',
'last_modified': '2023-08-30T14:21:38'},
'text': 'Conure',
'type': 'Title'},
{'element_id': '113bf8d250c2b1a77c9c2caa4b812f85',
'metadata': {'file_directory': '/home/matt/tmp',
'filename': 'parrots.xml',
'filetype': 'application/xml',
'last_modified': '2023-08-30T14:21:38'},
'text': 'A conure is a very friendly bird.\n'
'\n'
'Conures are feathery and like to dance.',
'type': 'NarrativeText'}]
```
2023-08-30 17:07:10 -04:00
|
|
|
from unstructured.documents.elements import NarrativeText, Title
|
2023-08-29 16:59:26 -04:00
|
|
|
from unstructured.partition.json import partition_json
|
2023-10-05 15:26:47 -05:00
|
|
|
from unstructured.partition.utils.constants import UNSTRUCTURED_INCLUDE_DEBUG_METADATA
|
2023-05-18 11:40:12 -04:00
|
|
|
from unstructured.partition.xml import partition_xml
|
2023-08-29 16:59:26 -04:00
|
|
|
from unstructured.staging.base import elements_to_json
|
2023-05-18 11:40:12 -04:00
|
|
|
|
2023-06-05 11:27:12 -07:00
|
|
|
DIRECTORY = pathlib.Path(__file__).parent.resolve()
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"filename",
|
|
|
|
["factbook.xml", "factbook-utf-16.xml"],
|
|
|
|
)
|
|
|
|
def test_partition_xml_from_filename(filename):
|
|
|
|
file_path = os.path.join(DIRECTORY, "..", "..", "example-docs", filename)
|
|
|
|
elements = partition_xml(filename=file_path, xml_keep_tags=False)
|
|
|
|
|
|
|
|
assert elements[0].text == "United States"
|
|
|
|
assert elements[0].metadata.filename == filename
|
2023-10-05 15:26:47 -05:00
|
|
|
if UNSTRUCTURED_INCLUDE_DEBUG_METADATA:
|
|
|
|
assert {element.metadata.detection_origin for element in elements} == {"xml"}
|
2023-05-18 11:40:12 -04:00
|
|
|
|
2023-06-05 11:27:12 -07:00
|
|
|
|
2023-07-05 15:02:22 -05:00
|
|
|
def test_partition_xml_from_filename_with_metadata_filename():
|
|
|
|
file_path = os.path.join(DIRECTORY, "..", "..", "example-docs", "factbook.xml")
|
|
|
|
elements = partition_xml(filename=file_path, xml_keep_tags=False, metadata_filename="test")
|
|
|
|
|
|
|
|
assert elements[0].text == "United States"
|
|
|
|
assert elements[0].metadata.filename == "test"
|
|
|
|
|
|
|
|
|
2023-06-05 11:27:12 -07:00
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"filename",
|
|
|
|
["factbook.xml", "factbook-utf-16.xml"],
|
|
|
|
)
|
|
|
|
def test_partition_xml_from_file(filename):
|
|
|
|
file_path = os.path.join(DIRECTORY, "..", "..", "example-docs", filename)
|
2023-09-27 21:34:06 -05:00
|
|
|
with open(file_path, "rb") as f:
|
2023-06-05 11:27:12 -07:00
|
|
|
elements = partition_xml(file=f, xml_keep_tags=False, metadata_filename=file_path)
|
2023-05-18 11:40:12 -04:00
|
|
|
|
|
|
|
assert elements[0].text == "United States"
|
2023-06-05 11:27:12 -07:00
|
|
|
assert elements[0].metadata.filename == filename
|
2023-05-18 11:40:12 -04:00
|
|
|
|
|
|
|
|
2023-07-05 15:02:22 -05:00
|
|
|
def test_partition_xml_from_file_with_metadata_filename():
|
|
|
|
file_path = os.path.join(DIRECTORY, "..", "..", "example-docs", "factbook.xml")
|
2023-09-27 21:34:06 -05:00
|
|
|
with open(file_path, "rb") as f:
|
2023-07-05 15:02:22 -05:00
|
|
|
elements = partition_xml(file=f, xml_keep_tags=False, metadata_filename="test")
|
|
|
|
|
|
|
|
assert elements[0].text == "United States"
|
|
|
|
assert elements[0].metadata.filename == "test"
|
|
|
|
|
|
|
|
|
2023-06-05 11:27:12 -07:00
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"filename",
|
|
|
|
["factbook.xml", "factbook-utf-16.xml"],
|
|
|
|
)
|
|
|
|
def test_partition_xml_from_file_rb(filename):
|
|
|
|
file_path = os.path.join(DIRECTORY, "..", "..", "example-docs", filename)
|
|
|
|
with open(file_path, "rb") as f:
|
|
|
|
elements = partition_xml(file=f, xml_keep_tags=False, metadata_filename=file_path)
|
2023-05-18 11:40:12 -04:00
|
|
|
|
|
|
|
assert elements[0].text == "United States"
|
2023-06-05 11:27:12 -07:00
|
|
|
assert elements[0].metadata.filename == filename
|
2023-05-18 11:40:12 -04:00
|
|
|
|
|
|
|
|
2023-06-05 11:27:12 -07:00
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"filename",
|
|
|
|
["factbook.xml", "factbook-utf-16.xml"],
|
|
|
|
)
|
|
|
|
def test_partition_xml_from_filename_with_tags_default_encoding(filename):
|
|
|
|
file_path = os.path.join(DIRECTORY, "..", "..", "example-docs", filename)
|
|
|
|
elements = partition_xml(filename=file_path, xml_keep_tags=True)
|
2023-05-18 11:40:12 -04:00
|
|
|
|
feat: `partition_xml` infers element type on each leaf node (#1249)
### Summary
Closes #1229. Updates `partition_xml` so that the element type is
inferred on each leaf node when `xml_keep_tags=False` instead of
delegating splitting and partitioning to `partition_xml`. If
`xml_keep_tags=True`, the file is treated like a text file still and
partitioning is still delegated to `partition_text`.
Also adds the option to pass `text` as an input to `partition_xml`.
### Testing
Create a `parrots.xml` file that looks like:
```xml
<xml><parrot><name>Conure</name><description>A conure is a very friendly bird.
Conures are feathery and like to dance.</description></parrot></xml>
```
Run:
```python
from unstructured.partition.xml import partition_xml
from unstructured.staging.base import convert_to_dict
elements = partition_xml(filename="parrots.xml")
convert_to_dict(elements)
```
One `main`, the output is the following. Notice how the `<name>` tag
incorrectly gets merged into `<description>` in the first element.
```python
[{'element_id': '7ae4074435df8dfcefcf24a4e6c52026',
'metadata': {'file_directory': '/home/matt/tmp',
'filename': 'parrots.xml',
'filetype': 'application/xml',
'last_modified': '2023-08-30T14:21:38'},
'text': 'Conure A conure is a very friendly bird.',
'type': 'NarrativeText'},
{'element_id': '859ecb332da6961acd2fb6a0185d1549',
'metadata': {'file_directory': '/home/matt/tmp',
'filename': 'parrots.xml',
'filetype': 'application/xml',
'last_modified': '2023-08-30T14:21:38'},
'text': 'Conures are feathery and like to dance.',
'type': 'NarrativeText'}]
```
One the feature branch, the output is the following, and the tags are
correctly separated.
```python
[{'element_id': '5512218914e4eeacf71a9cd42c373710',
'metadata': {'file_directory': '/home/matt/tmp',
'filename': 'parrots.xml',
'filetype': 'application/xml',
'last_modified': '2023-08-30T14:21:38'},
'text': 'Conure',
'type': 'Title'},
{'element_id': '113bf8d250c2b1a77c9c2caa4b812f85',
'metadata': {'file_directory': '/home/matt/tmp',
'filename': 'parrots.xml',
'filetype': 'application/xml',
'last_modified': '2023-08-30T14:21:38'},
'text': 'A conure is a very friendly bird.\n'
'\n'
'Conures are feathery and like to dance.',
'type': 'NarrativeText'}]
```
2023-08-30 17:07:10 -04:00
|
|
|
assert "<leader>Joe Biden</leader>" in elements[0].text
|
|
|
|
assert elements[0].metadata.filename == filename
|
|
|
|
|
|
|
|
|
|
|
|
def test_partition_xml_from_text_with_tags(filename="example-docs/factbook.xml"):
|
|
|
|
with open(filename) as f:
|
|
|
|
text = f.read()
|
|
|
|
elements = partition_xml(text=text, xml_keep_tags=True, metadata_filename=filename)
|
|
|
|
|
|
|
|
assert "<leader>Joe Biden</leader>" in elements[0].text
|
|
|
|
assert elements[0].metadata.filename == "factbook.xml"
|
2023-06-05 11:27:12 -07:00
|
|
|
|
2023-05-18 11:40:12 -04:00
|
|
|
|
2023-06-05 11:27:12 -07:00
|
|
|
@pytest.mark.parametrize(
|
|
|
|
("filename", "encoding", "error"),
|
|
|
|
[("factbook-utf-16.xml", "utf-8", UnicodeDecodeError)],
|
|
|
|
)
|
|
|
|
def test_partition_xml_from_filename_with_tags_raises_encoding_error(filename, encoding, error):
|
|
|
|
with pytest.raises(error):
|
|
|
|
file_path = os.path.join(DIRECTORY, "..", "..", "example-docs", filename)
|
|
|
|
partition_xml(filename=file_path, xml_keep_tags=True, encoding=encoding)
|
2023-05-18 11:40:12 -04:00
|
|
|
|
2023-06-05 11:27:12 -07:00
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"filename",
|
|
|
|
["factbook.xml", "factbook-utf-16.xml"],
|
|
|
|
)
|
|
|
|
def test_partition_xml_from_file_with_tags_default_encoding(filename):
|
|
|
|
file_path = os.path.join(DIRECTORY, "..", "..", "example-docs", filename)
|
|
|
|
with open(file_path) as f:
|
|
|
|
elements = partition_xml(file=f, xml_keep_tags=True, metadata_filename=file_path)
|
2023-05-18 11:40:12 -04:00
|
|
|
|
feat: `partition_xml` infers element type on each leaf node (#1249)
### Summary
Closes #1229. Updates `partition_xml` so that the element type is
inferred on each leaf node when `xml_keep_tags=False` instead of
delegating splitting and partitioning to `partition_xml`. If
`xml_keep_tags=True`, the file is treated like a text file still and
partitioning is still delegated to `partition_text`.
Also adds the option to pass `text` as an input to `partition_xml`.
### Testing
Create a `parrots.xml` file that looks like:
```xml
<xml><parrot><name>Conure</name><description>A conure is a very friendly bird.
Conures are feathery and like to dance.</description></parrot></xml>
```
Run:
```python
from unstructured.partition.xml import partition_xml
from unstructured.staging.base import convert_to_dict
elements = partition_xml(filename="parrots.xml")
convert_to_dict(elements)
```
One `main`, the output is the following. Notice how the `<name>` tag
incorrectly gets merged into `<description>` in the first element.
```python
[{'element_id': '7ae4074435df8dfcefcf24a4e6c52026',
'metadata': {'file_directory': '/home/matt/tmp',
'filename': 'parrots.xml',
'filetype': 'application/xml',
'last_modified': '2023-08-30T14:21:38'},
'text': 'Conure A conure is a very friendly bird.',
'type': 'NarrativeText'},
{'element_id': '859ecb332da6961acd2fb6a0185d1549',
'metadata': {'file_directory': '/home/matt/tmp',
'filename': 'parrots.xml',
'filetype': 'application/xml',
'last_modified': '2023-08-30T14:21:38'},
'text': 'Conures are feathery and like to dance.',
'type': 'NarrativeText'}]
```
One the feature branch, the output is the following, and the tags are
correctly separated.
```python
[{'element_id': '5512218914e4eeacf71a9cd42c373710',
'metadata': {'file_directory': '/home/matt/tmp',
'filename': 'parrots.xml',
'filetype': 'application/xml',
'last_modified': '2023-08-30T14:21:38'},
'text': 'Conure',
'type': 'Title'},
{'element_id': '113bf8d250c2b1a77c9c2caa4b812f85',
'metadata': {'file_directory': '/home/matt/tmp',
'filename': 'parrots.xml',
'filetype': 'application/xml',
'last_modified': '2023-08-30T14:21:38'},
'text': 'A conure is a very friendly bird.\n'
'\n'
'Conures are feathery and like to dance.',
'type': 'NarrativeText'}]
```
2023-08-30 17:07:10 -04:00
|
|
|
assert "<leader>Joe Biden</leader>" in elements[0].text
|
|
|
|
assert elements[0].metadata.filename == filename
|
2023-06-05 11:27:12 -07:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"filename",
|
|
|
|
["factbook.xml", "factbook-utf-16.xml"],
|
|
|
|
)
|
|
|
|
def test_partition_xml_from_file_rb_with_tags_default_encoding(filename):
|
|
|
|
file_path = os.path.join(DIRECTORY, "..", "..", "example-docs", filename)
|
|
|
|
with open(file_path, "rb") as f:
|
|
|
|
elements = partition_xml(file=f, xml_keep_tags=True, metadata_filename=file_path)
|
|
|
|
|
feat: `partition_xml` infers element type on each leaf node (#1249)
### Summary
Closes #1229. Updates `partition_xml` so that the element type is
inferred on each leaf node when `xml_keep_tags=False` instead of
delegating splitting and partitioning to `partition_xml`. If
`xml_keep_tags=True`, the file is treated like a text file still and
partitioning is still delegated to `partition_text`.
Also adds the option to pass `text` as an input to `partition_xml`.
### Testing
Create a `parrots.xml` file that looks like:
```xml
<xml><parrot><name>Conure</name><description>A conure is a very friendly bird.
Conures are feathery and like to dance.</description></parrot></xml>
```
Run:
```python
from unstructured.partition.xml import partition_xml
from unstructured.staging.base import convert_to_dict
elements = partition_xml(filename="parrots.xml")
convert_to_dict(elements)
```
One `main`, the output is the following. Notice how the `<name>` tag
incorrectly gets merged into `<description>` in the first element.
```python
[{'element_id': '7ae4074435df8dfcefcf24a4e6c52026',
'metadata': {'file_directory': '/home/matt/tmp',
'filename': 'parrots.xml',
'filetype': 'application/xml',
'last_modified': '2023-08-30T14:21:38'},
'text': 'Conure A conure is a very friendly bird.',
'type': 'NarrativeText'},
{'element_id': '859ecb332da6961acd2fb6a0185d1549',
'metadata': {'file_directory': '/home/matt/tmp',
'filename': 'parrots.xml',
'filetype': 'application/xml',
'last_modified': '2023-08-30T14:21:38'},
'text': 'Conures are feathery and like to dance.',
'type': 'NarrativeText'}]
```
One the feature branch, the output is the following, and the tags are
correctly separated.
```python
[{'element_id': '5512218914e4eeacf71a9cd42c373710',
'metadata': {'file_directory': '/home/matt/tmp',
'filename': 'parrots.xml',
'filetype': 'application/xml',
'last_modified': '2023-08-30T14:21:38'},
'text': 'Conure',
'type': 'Title'},
{'element_id': '113bf8d250c2b1a77c9c2caa4b812f85',
'metadata': {'file_directory': '/home/matt/tmp',
'filename': 'parrots.xml',
'filetype': 'application/xml',
'last_modified': '2023-08-30T14:21:38'},
'text': 'A conure is a very friendly bird.\n'
'\n'
'Conures are feathery and like to dance.',
'type': 'NarrativeText'}]
```
2023-08-30 17:07:10 -04:00
|
|
|
assert "<leader>Joe Biden</leader>" in elements[0].text
|
|
|
|
assert elements[0].metadata.filename == filename
|
2023-06-05 11:27:12 -07:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
("filename", "encoding", "error"),
|
|
|
|
[("factbook-utf-16.xml", "utf-8", UnicodeDecodeError)],
|
|
|
|
)
|
|
|
|
def test_partition_xml_from_file_rb_with_tags_raises_encoding_error(filename, encoding, error):
|
|
|
|
file_path = os.path.join(DIRECTORY, "..", "..", "example-docs", filename)
|
|
|
|
with pytest.raises(error), open(file_path, "rb") as f:
|
|
|
|
partition_xml(
|
|
|
|
file=f,
|
|
|
|
xml_keep_tags=True,
|
|
|
|
metadata_filename=file_path,
|
|
|
|
encoding=encoding,
|
|
|
|
)
|
2023-06-30 09:44:46 -05:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"filename",
|
|
|
|
["factbook.xml", "factbook-utf-16.xml"],
|
|
|
|
)
|
|
|
|
def test_partition_xml_from_filename_exclude_metadata(filename):
|
|
|
|
file_path = os.path.join(DIRECTORY, "..", "..", "example-docs", filename)
|
|
|
|
elements = partition_xml(filename=file_path, xml_keep_tags=False, include_metadata=False)
|
|
|
|
|
|
|
|
assert elements[0].text == "United States"
|
|
|
|
for i in range(len(elements)):
|
|
|
|
assert elements[i].metadata.to_dict() == {}
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"filename",
|
|
|
|
["factbook.xml", "factbook-utf-16.xml"],
|
|
|
|
)
|
|
|
|
def test_partition_xml_from_file_exclude_metadata(filename):
|
|
|
|
file_path = os.path.join(DIRECTORY, "..", "..", "example-docs", filename)
|
2023-09-27 21:34:06 -05:00
|
|
|
with open(file_path, "rb") as f:
|
2023-06-30 09:44:46 -05:00
|
|
|
elements = partition_xml(
|
|
|
|
file=f,
|
|
|
|
xml_keep_tags=False,
|
|
|
|
metadata_filename=file_path,
|
|
|
|
include_metadata=False,
|
|
|
|
)
|
|
|
|
|
|
|
|
assert elements[0].text == "United States"
|
|
|
|
for i in range(len(elements)):
|
|
|
|
assert elements[i].metadata.to_dict() == {}
|
2023-07-26 15:10:14 -04:00
|
|
|
|
|
|
|
|
|
|
|
def test_partition_xml_metadata_date(
|
|
|
|
mocker,
|
|
|
|
filename="example-docs/factbook.xml",
|
|
|
|
):
|
|
|
|
mocked_last_modification_date = "2029-07-05T09:24:28"
|
|
|
|
|
|
|
|
mocker.patch(
|
|
|
|
"unstructured.partition.xml.get_last_modified_date",
|
|
|
|
return_value=mocked_last_modification_date,
|
|
|
|
)
|
|
|
|
|
|
|
|
elements = partition_xml(
|
|
|
|
filename=filename,
|
|
|
|
)
|
|
|
|
|
2023-07-31 19:55:43 -07:00
|
|
|
assert elements[0].metadata.last_modified == mocked_last_modification_date
|
2023-07-26 15:10:14 -04:00
|
|
|
|
|
|
|
|
|
|
|
def test_partition_xml_with_custom_metadata_date(
|
|
|
|
mocker,
|
|
|
|
filename="example-docs/factbook.xml",
|
|
|
|
):
|
|
|
|
mocked_last_modification_date = "2029-07-05T09:24:28"
|
|
|
|
expected_last_modification_date = "2020-07-05T09:24:28"
|
|
|
|
|
|
|
|
mocker.patch(
|
|
|
|
"unstructured.partition.xml.get_last_modified_date",
|
|
|
|
return_value=mocked_last_modification_date,
|
|
|
|
)
|
|
|
|
|
|
|
|
elements = partition_xml(
|
|
|
|
filename=filename,
|
2023-07-31 19:55:43 -07:00
|
|
|
metadata_last_modified=expected_last_modification_date,
|
2023-07-26 15:10:14 -04:00
|
|
|
)
|
|
|
|
|
2023-07-31 19:55:43 -07:00
|
|
|
assert elements[0].metadata.last_modified == expected_last_modification_date
|
2023-07-26 15:10:14 -04:00
|
|
|
|
|
|
|
|
|
|
|
def test_partition_xml_from_file_metadata_date(
|
|
|
|
mocker,
|
|
|
|
filename="example-docs/factbook.xml",
|
|
|
|
):
|
|
|
|
mocked_last_modification_date = "2029-07-05T09:24:28"
|
|
|
|
|
|
|
|
mocker.patch(
|
|
|
|
"unstructured.partition.xml.get_last_modified_date_from_file",
|
|
|
|
return_value=mocked_last_modification_date,
|
|
|
|
)
|
|
|
|
|
|
|
|
with open(filename, "rb") as f:
|
|
|
|
elements = partition_xml(
|
|
|
|
file=f,
|
|
|
|
)
|
|
|
|
|
2023-07-31 19:55:43 -07:00
|
|
|
assert elements[0].metadata.last_modified == mocked_last_modification_date
|
2023-07-26 15:10:14 -04:00
|
|
|
|
|
|
|
|
|
|
|
def test_partition_xml_from_file_with_custom_metadata_date(
|
|
|
|
mocker,
|
|
|
|
filename="example-docs/factbook.xml",
|
|
|
|
):
|
|
|
|
mocked_last_modification_date = "2029-07-05T09:24:28"
|
|
|
|
expected_last_modification_date = "2020-07-05T09:24:28"
|
|
|
|
|
|
|
|
mocker.patch(
|
|
|
|
"unstructured.partition.xml.get_last_modified_date_from_file",
|
|
|
|
return_value=mocked_last_modification_date,
|
|
|
|
)
|
|
|
|
|
|
|
|
with open(filename, "rb") as f:
|
2023-07-31 19:55:43 -07:00
|
|
|
elements = partition_xml(file=f, metadata_last_modified=expected_last_modification_date)
|
2023-07-26 15:10:14 -04:00
|
|
|
|
2023-07-31 19:55:43 -07:00
|
|
|
assert elements[0].metadata.last_modified == expected_last_modification_date
|
2023-08-29 16:59:26 -04:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"filename",
|
|
|
|
["factbook.xml", "factbook-utf-16.xml"],
|
|
|
|
)
|
|
|
|
def test_partition_xml_with_json(filename):
|
|
|
|
file_path = os.path.join(DIRECTORY, "..", "..", "example-docs", filename)
|
|
|
|
elements = partition_xml(filename=file_path, xml_keep_tags=False)
|
|
|
|
test_elements = partition_json(text=elements_to_json(elements))
|
|
|
|
|
|
|
|
assert len(elements) == len(test_elements)
|
|
|
|
assert elements[0].metadata.page_number == test_elements[0].metadata.page_number
|
|
|
|
assert elements[0].metadata.filename == test_elements[0].metadata.filename
|
|
|
|
|
|
|
|
for i in range(len(elements)):
|
|
|
|
assert elements[i] == test_elements[i]
|
feat: `partition_xml` infers element type on each leaf node (#1249)
### Summary
Closes #1229. Updates `partition_xml` so that the element type is
inferred on each leaf node when `xml_keep_tags=False` instead of
delegating splitting and partitioning to `partition_xml`. If
`xml_keep_tags=True`, the file is treated like a text file still and
partitioning is still delegated to `partition_text`.
Also adds the option to pass `text` as an input to `partition_xml`.
### Testing
Create a `parrots.xml` file that looks like:
```xml
<xml><parrot><name>Conure</name><description>A conure is a very friendly bird.
Conures are feathery and like to dance.</description></parrot></xml>
```
Run:
```python
from unstructured.partition.xml import partition_xml
from unstructured.staging.base import convert_to_dict
elements = partition_xml(filename="parrots.xml")
convert_to_dict(elements)
```
One `main`, the output is the following. Notice how the `<name>` tag
incorrectly gets merged into `<description>` in the first element.
```python
[{'element_id': '7ae4074435df8dfcefcf24a4e6c52026',
'metadata': {'file_directory': '/home/matt/tmp',
'filename': 'parrots.xml',
'filetype': 'application/xml',
'last_modified': '2023-08-30T14:21:38'},
'text': 'Conure A conure is a very friendly bird.',
'type': 'NarrativeText'},
{'element_id': '859ecb332da6961acd2fb6a0185d1549',
'metadata': {'file_directory': '/home/matt/tmp',
'filename': 'parrots.xml',
'filetype': 'application/xml',
'last_modified': '2023-08-30T14:21:38'},
'text': 'Conures are feathery and like to dance.',
'type': 'NarrativeText'}]
```
One the feature branch, the output is the following, and the tags are
correctly separated.
```python
[{'element_id': '5512218914e4eeacf71a9cd42c373710',
'metadata': {'file_directory': '/home/matt/tmp',
'filename': 'parrots.xml',
'filetype': 'application/xml',
'last_modified': '2023-08-30T14:21:38'},
'text': 'Conure',
'type': 'Title'},
{'element_id': '113bf8d250c2b1a77c9c2caa4b812f85',
'metadata': {'file_directory': '/home/matt/tmp',
'filename': 'parrots.xml',
'filetype': 'application/xml',
'last_modified': '2023-08-30T14:21:38'},
'text': 'A conure is a very friendly bird.\n'
'\n'
'Conures are feathery and like to dance.',
'type': 'NarrativeText'}]
```
2023-08-30 17:07:10 -04:00
|
|
|
|
|
|
|
|
|
|
|
def test_partition_xml_with_narrative_line_breaks():
|
|
|
|
xml_text = """<xml>
|
|
|
|
<parrot>
|
|
|
|
<name>Conure</name>
|
|
|
|
<description>A conure is a very friendly bird.
|
|
|
|
Conures are feathery and like to dance.
|
|
|
|
</description>
|
|
|
|
</parrot>
|
|
|
|
</xml>"""
|
|
|
|
|
|
|
|
elements = partition_xml(text=xml_text)
|
|
|
|
assert elements[0] == Title("Conure")
|
|
|
|
assert isinstance(elements[1], NarrativeText)
|
|
|
|
assert str(elements[1]).startswith("A conure is a very friendly bird.")
|
|
|
|
assert str(elements[1]).strip().endswith("Conures are feathery and like to dance.")
|
2023-09-11 16:00:14 -05:00
|
|
|
|
|
|
|
|
|
|
|
def test_add_chunking_strategy_on_partition_xml(
|
|
|
|
filename="example-docs/factbook.xml",
|
|
|
|
):
|
|
|
|
elements = partition_xml(filename=filename)
|
|
|
|
chunk_elements = partition_xml(filename, chunking_strategy="by_title")
|
|
|
|
chunks = chunk_by_title(elements)
|
|
|
|
assert chunk_elements != elements
|
|
|
|
assert chunk_elements == chunks
|
2023-10-10 20:47:56 -05:00
|
|
|
|
|
|
|
|
|
|
|
def test_partition_xml_element_metadata_has_languages():
|
|
|
|
filename = "example-docs/factbook.xml"
|
|
|
|
elements = partition_xml(filename=filename)
|
|
|
|
assert elements[0].metadata.languages == ["eng"]
|
|
|
|
|
|
|
|
|
|
|
|
def test_partition_xml_respects_detect_language_per_element():
|
|
|
|
filename = "example-docs/language-docs/eng_spa_mult.xml"
|
|
|
|
elements = partition_xml(filename=filename, detect_language_per_element=True)
|
|
|
|
langs = [element.metadata.languages for element in elements]
|
|
|
|
assert langs == [["eng"], ["spa", "eng"], ["eng"], ["eng"], ["spa"]]
|