Office Open XML

No debe confundirse con el formato OpenDocument creado y popularizado mucho antes por programas como LibreOffice o Google Docs. Tampoco debe confundirse con OpenOffice.org XML (formato obsoleto usado por versiones anteriores de OpenOffice.org), o Microsoft Office XML (formato de archivo usado por versiones anteriores de Microsoft Office).
Documento Office Open XML
Desarrollador
Microsoft, Ecma, ISO/IEC
ECMA-376,
ISO/IEC 29500:2008
Información general
Extensión de archivo .docx, .docm
Tipo de MIME application/vnd.
openxmlformats-officedocument.
wordprocessingml.
document[1]
Número mágico PK
Tipo de formato Documento de texto
Extendido de XML, DOC, WordProcessingML
Estándar(es) ECMA-376, ISO/IEC 29500
Formato abierto Sí 
Presentación Office Open XML
Desarrollador
Microsoft, Ecma, ISO/IEC
ECMA-376,
ISO/IEC 29500:2008
Información general
Extensión de archivo .pptx
Tipo de MIME application/vnd.
openxmlformats-officedocument.
presentationml.
presentation[1]
Número mágico PK
Tipo de formato Presentación
Extendido de XML, PPT
Estándar(es) ECMA-376, ISO/IEC 29500
Formato abierto Sí 
Libro Office Open XML
Desarrollador
Microsoft, Ecma, ISO/IEC
ECMA-376,
ISO/IEC 29500:2008
Información general
Extensión de archivo .xlsx
Tipo de MIME application/vnd.
openxmlformats-officedocument.
spreadsheetml.
sheet[1]
Número mágico PK
Tipo de formato Hoja de cálculo
Extendido de XML, XLS, SpreadsheetML
Estándar(es) ECMA-376, ISO/IEC 29500
Formato abierto Sí 

Office Open XML (también llamado OOXML u OpenXML) es un formato de archivo abierto y estándar cuyas extensiones más comunes son .docx, .xlsx y .pptx. Se le utiliza para representar y almacenar hojas de cálculo, gráficas, presentaciones y documentos de texto. Un archivo Office Open XML contiene principalmente datos basados en el lenguaje de marcado XML, comprimidos en un contenedor .zip específico.

La especificación fue definida originalmente por Microsoft para reemplazar sus formatos binarios protegidos, además de los rudimentarios formatos de archivo basados en XML de Office 2003 (Microsoft Office XML). Dicha especificación fue luego entregada a Ecma International bajo la supervisión del Comité Técnico TC45 de Ecma International para ser desarrollada como el estándar ECMA-376,[2]​ proceso que culminó en 2006.[3][4][5][6][7][8][9]

Tras un par de años de trabajo y luego de incorporar algunos de los cambios propuestos por miembros de las organizaciones ISO/IEC, se publicó una versión corregida de la especificación como estándar internacional «ISO/IEC 29500:2008, Information technology – Office Open XML formats»,[10]​ y como «ECMA-376 Office Open XML File Formats - 2a edición». La normativa ISO/IEC 29500 publicada en noviembre de 2008, consta de 4 partes que pueden ser descargadas libremente para su consulta.[11]​ Esta aprobación fue realizada por la vía rápida,[12]​ sin seguir el procedimiento normal que sí tuvo que seguir el formato ODF (OpenDocument Format).[13][14]

Este formato es criticado por desarrolladores de suites que han querido añadir compatibilidad con OOXML. El estándar presenta dificultades técnicas para su implementación imposibilitando la creación de implementaciones alternativas a la de Microsoft, que no es abierta ni tampoco está documentada. También crea incompatibilidades (pérdida de información) al usarlo para intercambiar información entre distintas versiones de Microsoft Office.[13][14][15]

Antecedentes y proceso de estandarización

Antes de la versión 2007, las aplicaciones principales de la suite de programas Microsoft Office (primariamente Word, Excel y PowerPoint) almacenaban sus datos de manera predeterminada en archivos binarios. Históricamente, era difícil para otras aplicaciones interoperar con éstos, debido a la carencia de información disponible públicamente. Para el año 2007, Microsoft ofreció las especificaciones para estos formatos binarios bajo una licencia libre de derechos y desde ese año, la documentación de uso de estos formatos es descargable desde su sitio web bajo un acuerdo de licencia Microsoft Open Specification Promise.[16][17]​ Debido a que Microsoft mantenía en secreto los formatos de archivo mencionados anteriormente, otros productores de programas ofimáticos tenían grandes dificultades en alcanzar una total interoperabilidad. Microsoft fue blanco de presiones para adoptar un formato de archivo abierto, ya que muchas naciones en particular adoptaron reglamentos que exigían que sus documentos oficiales debían encontrarse disponibles en formatos abiertos.

En el año 2000, Microsoft publicó una versión inicial de un formato basado en XML para Microsoft Excel y que luego fue incorporado a Office XP. En el 2002 le siguió un formato similar para Microsoft Word.[18]​ Estos formatos de Word y Excel – conocidos como formatos Microsoft Office XML – serían incluidos en la versión 2003 de Microsoft Office.

Para mayo de 2004, algunos gobiernos además de la Unión Europea, hicieron la recomendación a Microsoft para que publicara y estandarizara sus formatos XML de Office a través de una organización especializada en esos procesos.[18][19]​ Microsoft anunció en noviembre de 2005 que iba a hacerlo con una nueva versión de sus formatos basados en XML mediante la intervención de Ecma International y que serían anunciados como "Ecma Office Open XML".[2]​ El estándar fue publicado como ECMA-376 y lanzado en diciembre de 2006.[20]​ La documentación puede ser descargada para su consulta desde el sitio web de Ecma International.[21]

Una versión corregida del formato recibió los votos necesarios para aprobarse como estándar ISO/IEC luego de un proceso de estandarización rápido realizado por el JTC 1 y que concluyó en abril de 2008.[12]

Versiones del estándar

La especificación Office Open XML existe en un número determinado de versiones.

ECMA-376 1a edición (2006)

El estándar ECMA está estructurado en cinco partes para lograr los requerimientos de distintas audiencias.[21]

Parte 1. Fundamentos
Vocabulario, convenciones de notación y abreviaturas
Resumen de los lenguajes de marcado principales y de soporte
Condiciones de adhesión y guías de interoperatividad
Restricciones del formato de empaquetado OPC que aplican a cada tipo de documento
Parte 2. Open Packaging Conventions
Define el formato Open Packaging Conventions (OPC), su modelo del paquete y empaquetado físico en las diversas aplicaciones que lo utilicen
Define las propiedades principales, miniaturas, firmas digitales, autorizaciones de acceso y cifrado
Los esquemas XML para OPC se declaran como XML Schema Definitions (XSD) y (no incluido en la normativa) utilizando RELAX NG (ISO/IEC 19757-2)
Parte 3. Cartilla
Introducción informativa (no normativa) a WordprocessingML, SpreadsheetML, PresentationML, DrawingML, VML y otros ML compartidos, proporcionando un contexto e ilustrando elementos a través de ejemplos y diagramas
Describe la institución de almacenamiento para los datos XML personalizados dentro de un contenedor, para soportar la integración con datos de negocios
Parte 4. Referencia del lenguaje de marcado
Contiene el material de referencia para WordprocessingML, SpreadsheetML, PresentationML, DrawingML, otros ML compartidos y esquemas XML personalizados, definiendo cada elemento y atributo e incluyendo la jerarquía del elemento (relaciones de parentesco)
Esquemas XML para los lenguajes de marcado, declarados como XSD y (no incluido en la normativa) utilizando RELAX NG
Define el mecanismo de almacenamiento para XML personalizado
Parte 5. Compatibilidad de marcado y extensibilidad
Describe los mecanismos de extensión de los documentos OpenXML y especifica los elementos o atributos por medio de los cuales las aplicaciones con extensiones distintas pueden interoperar.

ISO/IEC 29500:2008

El estándar ISO/IEC está estructurado en cuatro partes, siendo cada una de ellas estándares independientes.[22]

Parte 1. Fundamentos y referencia del lenguaje de marcado (5560 páginas)
Contiene definiciones de conformación
Contiene el material de referencia para WordprocessingML, SpreadsheetML, PresentationML, DrawingML, otros ML compartidos y esquemas XML personalizados, definiendo cada elemento y atributo e incluyendo la jerarquía del elemento (relaciones de parentesco)
Esquemas XML para los lenguajes de marcado, declarados como XSD y (no incluido en la normativa) utilizando RELAX NG
Define la institución de almacenamiento para los datos XML personalizados
Se incluyen los esquemas XML en el texto
Parte 2. Open Packaging Conventions (129 páginas)
Define el formato Open Packaging Conventions (modelo del paquete, empaquetado físico)
Define las propiedades principales, miniaturas y firmas digitales
Los esquemas XML para OPC son declarados como XML Schema Definitions (XSD) y (no incluido en la normativa) utilizando RELAX NG (ISO/IEC 19757-2)
Parte 3. Compatibilidad de marcado y extensibilidad (40 páginas)
Describe los mecanismos de extensión de los documentos OpenXML y especifica los elementos o atributos por medio de los cuales, las aplicaciones con extensiones distintas pueden interoperar
Las reglas de extensibilidad son expresadas utilizando NVDL (ISO/IEC 19757-4)
Parte 4. Características de migración transicionales (1464 páginas)
Contiene material de referencia de interés transicional
Contiene material controvertido como la configuración de compatibilidad y el lenguaje de marcado gráfico VML
Contiene una lista de diferencias entre ECMA-376 e ISO/IEC 29500:2008

El estándar especifica un total seis niveles de tolerancia del documento o aplicación. Niveles strict (estricto) y transitional (de transición) para cada lenguaje (WordprocessingML, PresentationML y SpreadsheetML). El estándar también especifica las descripciones de aplicaciones tales como base y full (completo).

Compatibilidad

A día de hoy Microsoft Office sigue sin soportar el formato OOXML establecido por el estándar ISO/IEC 29500 por defecto.[13]​ Aunque aparentemente se puede seleccionar manualmente que guarde los documentos en dicho formato a partir de Microsoft Office 2013,[23]​ la configuración de Microsoft Office provoca incompatibilidades e imposibilidad de intercambiar documentos en OOXML de forma ágil. Hay múltiples versiones distintas del estándar (ECMA, ISO, por cada versión de Microsoft Office), pudiéndose implementar en teoría solamente una versión (la «Strict») por agentes externos a Microsoft. En la práctica, la versión «Strict» del estándar sin extensiones no la utiliza nadie ya que Microsoft usa su implementación con extensiones propias.[13]​ Esto es problemático puesto que la implementación «Strict» de Microsoft y sus extensiones no están documentadas, no son abiertas, se pueden cambiar sin previo aviso y tienen el potencial de crecer en número indefinidamente. La especificación «Markup Compatibility and Extensibility» (MCE, partes 5 y 3 del estándar ECMA e ISO, respectivamente) permite respetar el estándar, incluido el «Strict» aunque se introduzcan etiquetas adicionales, sean propietarias o no. Las extensiones de Microsoft son propietarias. La forma de ser compatible con las extensiones si no son soportadas por el programa consiste en ignorar esos contenidos o degradarlos, ocasionando pérdida de información.[13][24]​ Se puede interpretar como un caso de Adoptar, Extender y Extinguir, presentando una filosofía cuyo objetivo es operar sólo con entornos Microsoft sin tener en cuenta el resto de suites ofimáticas.[15]

Aplicaciones que soportan el formato

Comenzando con Microsoft Office 2007, los formatos de archivo Office Open XML (ECMA-376) son el formato predeterminado para guardar documentos de Microsoft Office.[25][26]​ Aunque se dijo en un principio,[27][28][29]​ la versión 2010 no implementa el formato compatible con ISO de Office Open XML (ISO 29500) y por ende, se incluye sólo una variante de transición del estándar, la ECMA.[30][31]​ Declaraciones hechas por Doug Mahugh, profesional del equipo de interoperabilidad de Microsoft, indican que el soporte a su formato «estricto» del estándar estará disponible en una futura versión 15 de la suite ofimática de la empresa, y probablemente se añada soporte a Microsoft Office 2010 mediante un plug-in o Service Pack.[32][33]

La suite Office 2010 de SoftMaker indica que puede leer y escribir archivos .DOCX y .XLSX en sus aplicaciones de procesador de textos y hoja de cálculo.

La suite OpenOffice.org puede importar archivos Office Open XML (.docx, .xlsx, .pptx, etc.) desde su versión 3.[34]

La suite LibreOffice puede importar archivos Office Open XML (.docx, .xlsx, .pptx, etc.) desde su versión 3.3.[35]

Otros productos ofimáticos que han comenzado a soportar el formato son TextEdit de Apple (incluido en Mac OS X) e iWork, IBM Lotus Notes, Corel Wordperfect y Google docs.

Restricciones al soporte de funcionalidad o compatibilidad son aplicables en función del archivo OOXML.

Características técnicas del formato

Componentes principales de Office Open XML.

El formato Office Open XML utiliza un contenedor basado en Open Packaging Conventions. Este formato utiliza mecanismos heredados del formato de compresión ZIP y contiene los archivos individuales que forman la base del documento. Además de lenguaje de marcado, el contenedor también puede integrar otros archivos como imágenes, vídeos u otros documentos.

Lenguajes de marcado

Un archivo Office Open XML puede contener muchos documentos codificados en lenguajes de marcado especializados, correspondientes a diversas aplicaciones dentro de la línea de productos de Microsoft Office. El formato Office Open XML define vocabularios múltiples utilizando para ello módulos de 27 espacios de nombres y 89 lenguajes de esquema.

Los lenguajes de marcado principales son:

  • WordprocessingML para documentos de texto
  • SpreadsheetML para hojas de cálculo
  • PresentationML para presentaciones

Algunos materiales compartidos con los lenguajes de marcado incluyen:

  • Lenguaje de marcado Office Math (OMML)
  • DrawingML, utilizado para dibujar vectores, gráficos, y text art (además, aunque no aprobado, VML se soporta como lenguaje de dibujo)
  • Propiedades extendidas
  • Propiedades personalizadas
  • Tipos variables
  • Propiedades de datos XML personalizadas
  • Bibliografía

Además de los lenguajes de marcado mencionados, se pueden usar esquemas XML personalizados para extender aún más Office Open XML.

El esquema XML de Office Open XML enfatiza el reducir el tiempo de carga y mejorar la velocidad de análisis sintáctico. Para mejorar el rendimiento, Office Open XML utiliza nombres de elementos muy cortos para aquellos elementos comunes y las hojas de cálculo guardan datos como números de índice (comenzando la numeración desde 1899 o desde 1904). Para lograr ser sistemático y genérico, Office Open XML usa típicamente elementos derivados separados para datos y metadatos (nombres de elementos que terminan en Pr para propiedades) en lugar de usar atributos múltiples que permitan propiedades estructuradas. Office Open XML no utiliza contenido mixto, pero utiliza algunos elementos para colocar series de text runs (nombre de elemento, r) en párrafos (nombre de elemento, p). En contraste, el resultado es conciso y altamente jerarquizado al compararse, por ejemplo con HTML que es bastante plano, ya que fue diseñado para escribir en editores de texto siendo a la vez más agradable de leer.

Office MathML (OMML)

El lenguaje de marcado Office Math es un lenguaje de marcado matemático el cual puede integrarse dentro de WordprocessingML, y que incluye soporte intrínseco para otros lenguajes de marcado de procesamiento de palabras como marcas de revisión,[36]​ notas al pie, comentarios, imágenes y otros estilos de contenido.[37]​ El formato OMML es distinto a la recomendación del World Wide Web Consortium (W3C), MathML, el cual, aunque no soporta esas características ofimáticas es parcialmente compatible[38]​ a través de transformaciones XSL relativamente simples.

El siguiente ejemplo de Office MathML define la fracción:

<m:oMathPara>
  <m:oMath>
    <m:f>
      <m:num><m:r>
        <m:t>π</m:t>
      </m:r></m:num>
      <m:den><m:r>
        <m:t>2</m:t>
      </m:r></m:den>
    </m:f>
  </m:oMath>
</m:oMathPara>

DrawingML

Ejemplo de gráfico realizado mediante DrawingML.

DrawingML es el lenguaje de marcado para gráficos vectoriales utilizado en documentos Office Open XML. Sus papel principal es renderizar los gráficos de elementos de texto, formas gráficas basadas en vectores, tablas y diagramas.

DrawingML es el tercer modelo de tablas en Office Open XML (luego de los modelos de tablas en WordprocessingML y SpreadsheetML) y está optimizado para efectos gráficos como sombras y reflejos que pueden ser utilizadas en diferentes elementos gráficos. Fue creado para un uso principal por parte del lenguaje PresentationML. Es posible crear efectos 3d en DrawingML para por ejemplo, mostrar diversos elementos gráficos mediante un ángulo de visión flexible. También es posible crear temas de diseño separados mediante DrawingML en un contenedor Office Open XML. Estos temas pueden ser aplicados a elementos gráficos a través de todo el contenido dentro del contenedor Office Open XML.[39]

El lenguaje DrawingML no está relacionado con otros formatos de gráficos vectoriales como SVG, aunque pueden ser convertidos a DrawingML para incluirse nativamente en un documento Office Open XML. Esta es una aproximación distinta a la del formato OpenDocument, el cual utiliza un subconjunto de SVG e incluye los gráficos vectoriales en archivos separados.

Las dimensiones de un gráfico DrawingML están especificadas en Unidades Métricas Inglesas (del inglés English Metric Unit o EMUs). Esta unidad se define como la 1/360.000 parte de un centímetro y por ende, hay 914.400 EMUs en una pulgada y 12.700 EMUs por punto. Se escogió esta unidad con aras de que se pudiesen utilizar números enteros para representar con precisión la mayoría de dimensiones encontradas en un documento. Las operaciones de coma flotante no pueden representar adecuadamente una fracción que no sea resultado de la suma de las potencias de dos y ese error se amplifica cuando las fracciones se suman juntas varias veces resultando en un desajuste. Ya que una pulgada equivale a 2.54 centímetros o 127/50, la pulgada debe ser dividida en 127 para que los valores de pulgada y centímetro se conviertan en enteros. Para representar de manera precisa un decimal en dos dígitos, se necesita un divisor de 100. Para representar un punto, es necesario un divisor de 72, lo cual permite también a divisiones de 2, 3, 4, 6, 8, 9, 12, 18, 24, y 36 ser exactas. Al multiplicar estos valores da como resultado 127×72×100 = 914.400 unidades por pulgada (el mínimo común múltiplo daría valores de 228.600 por pulgada y 90.000 por centímetro). De acuerdo con Rick Jelliffe, programador y activista de estándares (ISO, W3C, IETF), las EMUs son una solución racional para un conjunto de criterios de diseño.[40]

Estructura del contenedor

Estructura del contenedor según la Parte 2 del estándar Ecma Office Open XML, ECMA-376.

Los documentos Office Open XML son almacenados en contenedores Open Packaging Convention (OPC), los cuales son archivos ZIP que guardan XML y otros archivos de datos, junto con las especificaciones de relación entre ellos.[41]​ Dependiendo del tipo de documento, los contenedores difieren en sus estructuras y nombres de directorios. Una aplicación usará los archivos de relación para localizar secciones individuales (en archivos), cada una con metadatos adjuntos, en particular metadatos MIME.

Un contenedor básico incluye en su raíz un archivo XML denominado [Content_Types].xml, junto con tres directorios: _rels, docProps, y uno específico para el tipo de documento (por ejemplo, en un paquete de texto .docx, habrá un directorio llamado word). El directorio word contendrá un archivo document.xml el cual incluye el texto base del documento.

[Content_Types].xml
Este archivo describe los contenidos globales. También contiene estructuras de mapeo para extensiones de archivos y reemplazos para URIs específicas.
_rels
Estos directorios contienen las relaciones de los archivos dentro del contenedor. Contendrá los mismos nombres de archivo que indican relaciones pero con una extensión .rels añadida. Por ejemplo, si el archivo content types tuviese alguna relación, existirá una archivo de nombre [Content_Types].xml.rels dentro del directorio _rels.
_rels/.rel
En este archivo se localizan las relaciones del contenedor. Las aplicaciones miran aquí primero. En un documento de contenido mínimo que sólo incluya el archivo básico document.xml, las relaciones detalladas son metadatos y document.xml.
docProps/core.xml
Este archivo contiene las propiedades base de cualquier documento Office Open XML.

Relaciones

Archivos de relación en Office Open XML

A continuación, un ejemplo de archivo de relación (word/_rels/document.xml.rels):

<?xml version="1.0" encoding="UTF-8" standalone="yes" ?>
<Relationships
  xmlns="http://schemas.microsoft.com/package/2005/06/relationships">
  <Relationship Id="rId1"
    Type="http://schemas.microsoft.com/office/2006/relationships/image"
    Target="http://web.archive.org/web/http://en.wikipedia.org/images/wiki-en.png"
    TargetMode="External" />
  <Relationship Id="rId2"
    Type="http://schemas.microsoft.com/office/2006/relationships/hyperlink"
    Target="http://www.wikipedia.org"
    TargetMode="External" />
</Relationships>

Con ello, las imágenes referenciadas en el documento pueden encontrarse en el archivo de relaciones si se busca por las relaciones que son de tipo http://schemas.microsoft.com/office/2006/relationships/image. Para cambiar la imagen usada, es necesario editar la relación.

Relaciones de hipervínculos

El siguiente código muestra un ejemplo de marcado entre líneas para un hipervínculo:

<w:hyperlink r:id="rId2" w:history="1"
  xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" 
  xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main">

En este ejemplo, el Localizador Uniforme de Recursos (URL) está representado por "rId2". La URL realmente se encuentra en el archivo de relaciones que le acompaña, localizado por su elemento "rId2" correspondiente. Las imágenes, plantillas y otros elementos vinculables son referenciados de la misma manera.

Relaciones para archivos de medios integrados o vinculados

Las imágenes pueden ser incorporadas o vinculadas usando una etiqueta:

<v:imagedata w:rel="rId1" o:title="ejemplo" />

Esta es la referencia al archivo de imagen. Todas las referencias son administradas mediante relaciones. Por ejemplo, el archivo document.xml se relaciona con la imagen. Hay un directorio _rels en el mismo directorio que document.xml; dentro de _rels hay un archivo llamado document.xml.rels. En ese archivo hay definiciones de relación que contiene tipo, ID y ubicación. La ID es la utilizada como referencia en el documento XML. El tipo será un esquema de definición para los tipos de medios y la ubicación será definida como la localización interna dentro del contenedor ZIP o externa, definida con una URL.

Propiedades del documento

Office Open XML utiliza el conjunto de elementos de metadatos Dublin Core y definiciones de metadatos DCMI para almacenar las propiedades del documento. Dublin Core es un estándar para descripción de recursos entre dominios y como tal, está definido en ISO 15836:2003.

Metadatos

El siguiente es un ejemplo del archivo de propiedades (docProps/core.xml) que utiliza metadatos Dublin Core:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<cp:coreProperties xmlns:cp="http://schemas.openxmlformats.org/package/2006/metadata/core-properties"
  xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:dcterms="http://purl.org/dc/terms/"
  xmlns:dcmitype="http://purl.org/dc/dcmitype/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <dc:title>Office Open XML</dc:title>
  <dc:subject>Formato y estructura de archivo</dc:subject>
  <dc:creator>Wikipedia</dc:creator>
  <cp:keywords>Office Open XML, Metadatos, Dublin Core</cp:keywords>
  <dc:description>Office Open XML usa ISO 15836:2003</dc:description>
  <cp:lastModifiedBy>Wikipedia</cp:lastModifiedBy>
  <cp:revision>1</cp:revision>
  <dcterms:created xsi:type="dcterms:W3CDTF">2008-06-19T20:00:00Z</dcterms:created>
  <dcterms:modified xsi:type="dcterms:W3CDTF">2008-06-19T20:42:00Z</dcterms:modified>
  <cp:category>Documentos sobre formatos de archivo</cp:category>
  <cp:contentStatus>Final</cp:contentStatus>
</cp:coreProperties>

Véase también

Referencias

  1. a b c Microsoft. «Register file extensions on third party servers». microsoft.com. Archivado desde el original el 20 de abril de 2008. Consultado el 9 de abril de 2008. 
  2. a b «Microsoft Co-Sponsors Submission of Office Open XML Document Formats to Ecma International for Standardization». Microsoft. 21 de noviembre de 2005. Archivado desde el original el 21 de diciembre de 2007. 
  3. http://www.ecma-international.org/activities/General/presentingecma.ppt
  4. Ecma formal publications
  5. Microsoft PowerPoint - BSI OOXML v1b.ppt
  6. «Information Technology Division - Executive Office for Administration & Finance» (en inglés). Archivado desde el original el 24 de enero de 2009. Consultado el 2009. 
  7. https://web.archive.org/web/20090306062707/http://www.itscj.ipsj.or.jp/sc34/open/1026.pdf
  8. «Office Open XML wird als weltweiter ISO/IEC-Standard anerkannt». ntz Fachzeitschrift für Informations- und Kommunikationstechnik (en alemán) (Berlin: VDE-Verlag) (3-4): 10. 2008. ISSN 0948-728X. Archivado desde el original el 2 de marzo de 2009. Consultado el 3 de febrero de 2009. 
  9. Techtree.com India > News > Software > ISO puts Microsoft's OOXML Standard on Hold
  10. ISO/IEC (18 de noviembre de 2008). «Publication of ISO/IEC 29500:2008, Information technology - Office Open XML formats». ISO. Archivado desde el original el 6 de julio de 2009. Consultado el 19 de noviembre de 2008. 
  11. «Freely Available Standards». ITTF (ISO). 18 de noviembre de 2008. 
  12. a b International Standards Organization (2 de abril de 2008). «ISO/IEC DIS 29500 receives necessary votes for approval as an International Standard» (en inglés). Archivado desde el original el 22 de agosto de 2017. Consultado el 21 de agosto de 2017. 
  13. a b c d e Markus Feilner (23 de junio de 2014). «Complex singularity versus openness» (en inglés). Observatorio Europeo del Código Abierto. Consultado el 21 de agosto de 2017. 
  14. a b Richard M. Stallman. «Entre todos podemos poner fin a los adjuntos en formato Word». www.gnu.org. Consultado el 17 de septiembre de 2017. 
  15. a b «ODF/OOXML technical white paper». freesoftwaremagazine.com (en inglés). 2 de mayo de 2007. Consultado el 17 de septiembre de 2017. 
  16. «How to extract information from Office files by using Office file formats and schemas». Microsoft. 27 de marzo de 2007. Consultado el 10 de julio de 2007. 
  17. «Microsoft Office Binary (doc, xls, ppt) File Formats». Microsoft. 15 de febrero de 2008. Archivado desde el original el 9 de abril de 2008. Consultado el 5 de abril de 2008. 
  18. a b Brian Jones (25 de enero de 2007). «History of office XML formats (1998–2006)». MSDN blogs. 
  19. Telematics between Administrations Committee based on IDA expert group on open document formats (25 de mayo de 2004). «TAC approval on conclusions and recommendations on open document formats». IDABC - European eGovernment Services. Archivado desde el original el 19 de agosto de 2007. Consultado el 30 de julio de 2007. 
  20. «Ecma International approves Office Open XML standard». Ecma International. 7 de diciembre de 2006. Consultado el 8 de diciembre de 2006. 
  21. a b Standard ECMA-376
  22. Rex Jaeshke - project editor (26 de septiembre de 2008). «N1080 Final Text for ISO/IEC 29500-1, Information technology -- Document description and processing languages -- Office Open XML File Formats -- Part 1: Fundamentals and Markup Language Reference». ISO/IEC JTC1 SC34. Archivado desde el original el 28 de marzo de 2009. Consultado el 22 de mayo de 2009. 
  23. «Why does Writer offer two options for saving in DOCX format?» (en inglés). 12 de julio de 2012. Consultado el 2017. 
  24. «The Document Foundation, LibreOffice and OOXML» (en inglés). Consultado el 21 de agosto de 2017. 
  25. «Microsoft's future lies somewhere beyond the Vista by Evansville Courier & Press». Archivado desde el original el 10 de julio de 2014. Consultado el 2009. 
  26. «Rivals Set Their Sights on Microsoft Office: Can They Topple the Giant? - Knowledge@Wharton». Consultado el 2009. 
  27. Microsoft Expands List of Formats Supported in Microsoft Office
  28. «FAQ: Office 14 and Microsoft's support for ODF». Archivado desde el original el 24 de diciembre de 2008. Consultado el 2009. 
  29. «Microsoft Office 2007 to Support ODF - and not OOXML - ConsortiumInfo.org». Archivado desde el original el 23 de mayo de 2008. Consultado el 2009. 
  30. ISO OOXML convener: Microsoft's format "heading for failure"
  31. Microsoft Fails the Standards Test Archivado el 4 de abril de 2010 en Wayback Machine.
  32. Doug Mahugh (6 de abril de 2010). «Office’s Support for ISO/IEC 29500 Strict» (en inglés). Consultado el 1010. 
  33. Ars Technica, ed. (7 de abril de 2010). «Microsoft: Office 15—not 2010—to be fully OOXML compliant» (en inglés). Consultado el 2010. 
  34. «OpenOffice.org 3.0 New Features» (en inglés). 13 de octubre de 2008. Consultado el 24 de octubre de 2009. 
  35. «LibreOffice 3.3 Feature List» (en inglés). Consultado el 21 de agosto de 2017. 
  36. Jesper Lund Stocholm (29 de enero de 2008). «Do your math - OOXML and OMML». A Mooh Point blog. Archivado desde el original el 10 de febrero de 2008. Consultado el 12 de febrero de 2008. 
  37. Murray Sargent (5 de junio de 2007). «Science and Nature have difficulties with Word 2007 mathematics». MSDN blogs. Consultado el 31 de julio de 2007. 
  38. David Carlisle (9 de mayo de 2007). «XHTML and MathML from Office 2007». David Carlisle. Consultado el 20 de septiembre de 2007. 
  39. Wouter Van Vugt (1 de noviembre de 2008). «Open XML Explained e-book». Openxmldeveloper.org. Archivado desde el original el 28 de octubre de 2007. Consultado el 14 de septiembre de 2007. 
  40. «Why EMUs? - O'Reilly XML Blog». Consultado el 2009. 
  41. Tom Ngo (11 de diciembre de 2006). «Office Open XML Overview» (PDF). Ecma International. p. 6. Consultado el 23 de enero de 2007. 

Enlaces externos