You do not normally need to create instances of this class. You access custom parts
related to the OOXML package via the Document.package_custom_parts property.
Shows how to access a document’s arbitrary custom parts collection.
doc=aw.Document(MY_DIR+'Custom parts OOXML package.docx')self.assertEqual(2,doc.package_custom_parts.count)# Clone the second part, then add the clone to the collection.cloned_part=doc.package_custom_parts[1].clone()doc.package_custom_parts.add(cloned_part)self.assertEqual(3,doc.package_custom_parts.count)# Enumerate over the collection and print every part.forindex,partinenumerate(doc.package_custom_parts):print(f'Part index {index}:')print(f'\tName:\t\t\t\t{part.name}')print(f'\tContent type:\t\t{part.content_type}')print(f'\tRelationship type:\t{part.relationship_type}')ifpart.is_external:print('\tSourced from outside the document')else:print(f'\tStored within the document, length: {len(part.data)} bytes')# We can remove elements from this collection individually, or all at once.doc.package_custom_parts.remove_at(2)self.assertEqual(2,doc.package_custom_parts.count)doc.package_custom_parts.clear()self.assertEqual(0,doc.package_custom_parts.count)