Source code for openpyxl.packaging.core

from __future__ import absolute_import
# Copyright (c) 2010-2019 openpyxl

import datetime

from openpyxl.compat import safe_string, unicode
from openpyxl.utils.datetime import (
    CALENDAR_WINDOWS_1900,
    to_ISO8601,
    from_ISO8601,
)
from openpyxl.descriptors import (
    String,
    DateTime,
    Alias,
    )
from openpyxl.descriptors.serialisable import Serialisable
from openpyxl.descriptors.nested import NestedText
from openpyxl.xml.functions import (Element, tostring)
from openpyxl.xml.constants import (
    COREPROPS_NS,
    DCORE_NS,
    XSI_NS,
    DCTERMS_NS,
    DCTERMS_PREFIX
)

[docs]class NestedDateTime(DateTime, NestedText): expected_type = datetime.datetime
[docs] def to_tree(self, tagname=None, value=None, namespace=None): namespace = getattr(self, "namespace", namespace) if namespace is not None: tagname = "{%s}%s" % (namespace, tagname) el = Element(tagname) if value is not None: el.text = to_ISO8601(value) return el
[docs]class QualifiedDateTime(NestedDateTime): """In certain situations Excel will complain if the additional type attribute isn't set"""
[docs] def to_tree(self, tagname=None, value=None, namespace=None): el = super(QualifiedDateTime, self).to_tree(tagname, value, namespace) el.set("{%s}type" % XSI_NS, "dcterms:W3CDTF") return el
[docs]class DocumentProperties(Serialisable): """High-level properties of the document. Defined in ECMA-376 Par2 Annex D """ tagname = "coreProperties" namespace = COREPROPS_NS category = NestedText(expected_type=unicode, allow_none=True) contentStatus = NestedText(expected_type=unicode, allow_none=True) keywords = NestedText(expected_type=unicode, allow_none=True) lastModifiedBy = NestedText(expected_type=unicode, allow_none=True) lastPrinted = NestedDateTime(allow_none=True) revision = NestedText(expected_type=unicode, allow_none=True) version = NestedText(expected_type=unicode, allow_none=True) last_modified_by = Alias("lastModifiedBy") # Dublin Core Properties subject = NestedText(expected_type=unicode, allow_none=True, namespace=DCORE_NS) title = NestedText(expected_type=unicode, allow_none=True, namespace=DCORE_NS) creator = NestedText(expected_type=unicode, allow_none=True, namespace=DCORE_NS) description = NestedText(expected_type=unicode, allow_none=True, namespace=DCORE_NS) identifier = NestedText(expected_type=unicode, allow_none=True, namespace=DCORE_NS) language = NestedText(expected_type=unicode, allow_none=True, namespace=DCORE_NS) # Dublin Core Terms created = QualifiedDateTime(allow_none=True, namespace=DCTERMS_NS) modified = QualifiedDateTime(allow_none=True, namespace=DCTERMS_NS) __elements__ = ("creator", "title", "description", "subject","identifier", "language", "created", "modified", "lastModifiedBy", "category", "contentStatus", "version", "revision", "keywords", "lastPrinted", ) def __init__(self, category=None, contentStatus=None, keywords=None, lastModifiedBy=None, lastPrinted=None, revision=None, version=None, created=datetime.datetime.now(), creator="openpyxl", description=None, identifier=None, language=None, modified=datetime.datetime.now(), subject=None, title=None, ): self.contentStatus = contentStatus self.lastPrinted = lastPrinted self.revision = revision self.version = version self.creator = creator self.lastModifiedBy = lastModifiedBy self.modified = modified self.created = created self.title = title self.subject = subject self.description = description self.identifier = identifier self.language = language self.keywords = keywords self.category = category