Blog sobre desarrollo WordPress en Español Desarrollo WordPress en Español
WP-CLI

WP-CLI Parte 7, importar y exportar contenido

 

Séptima entrega de la serie sobre WP-CLI. En esta ocasión vamos a ver cómo exportar e importar contenido en nuestra web.

Para ello, disponemos de los comandos wp export y wp import.

 

Exportar contenido con WP-CLI

A través del comando wp export podemos exportar el contenido a un fichero WXR. Este fichero contendrá la información sobre autores, términos, entradas, comentarios y adjuntos. No incluye configuración del sitio (options) ni los propios ficheros de los archivos adjuntos.

Admite los siguientes parámetros:

  • [--dir=<dirname>], ruta completa donde se almacenará el fichero WXR. Por defecto es el actual directorio desde el que estamos ejecutando el comando.
  • [--skip_comments], para no incluir los comentarios en el archivo WXR.
  • [--max_file_size=<MB>], para establecer en megas el tamaño máximo del archivo WXR. Por defecto 15
  • [--start_date=<date>], para establecer una fecha de publicación a partir de la cual exportar el contenido. El formato de fecha debe ser YYYY-MM-DD.
  • [--end_date=<date>], para exportar entradas que tengan como tope esta fecha de publicación. El formato de fecha debe ser YYYY-MM-DD.
  • [--post_type=<post-type>], para exportar las entradas de un tipo de contenido concreto. Pueden establecerse varios tipos de contenido separados por coma. Ej: post,page,product… Por defecto se exporta todo (any)
  • [--post_type__not_in=<post-type>], al contrario que el anterior, para exportar las entradas excepto de los tipos de contenido indicados. Pueden establecerse varios tipos de contenido separados por coma.
  • [--post__in=<pid>], para exportar todos los posts especificados. Admite una lista de IDs separados por coma o espacio.
  • [--start_id=<pid>], para exportar todos los posts con ID igual o superior al indicado (número).
  • [--author=<author>], para exportar todos los posts que ha creado un usuario concreto. Se puede identificar al usuario por ID o por nombre de usuario (user_login).
  • [--category=<name>], para exportar todos los posts de una categoría concreta.
  • [--post_status=<status>], para exportar todos los posts que se encuentren en un determinado status (publish, future, draft, trash…).
  • [--filename_format=<format>], para especificar un formato al nombre de fichero que se va a exportar. Por defecto: ‘{site}.wordpress.{date}.{n}.xml’.

 

Como puede observarse, disponemos de multitud de filtros para exportar contenido muy concreto: entre fechas, de un autor determinado, de una categoría determinada, de un tipo de contenido concreto, etc… Veamos algunos ejemplos:

Por ejemplo, para exportar todos los posts de la categoría noticias:

wp export

Otro ejemplo, exportar todos los post del custom post type eventos entre dos fechas. Por ejemplo: todos los eventos del año 2017:

También podemos hilar un poco más fino y concatenar varios comandos, como por ejemplo para exportar todos los posts que tengan un custom field con un determinado valor:

 

Importar contenido con WP-CLI

Siempre que hablamos de exportar, lo siguiente es hacerlo de importar. Para este caso el comando es wp import. Este comando lo que hace es importar el contenido desde un fichero WXR. Éstos son los parámetros que acepta:

  • <file>…, ruta a uno o más ficheros WXR válidos. Además de la ruta completa a un fichero concreto, también son aceptados directorios.
  • --authors=<authors>, para indicar cómo manejar el mapeo de autores. Las opciones que acepta este parámetro son: ‘create’, ‘mapping.csv’, o ‘skip’. Para más información te aconsejo que leas la documentación oficial.
  • [--skip=<data-type>], para saltar la importación de datos específicos. Las opciones que acepta este parámetro son: ‘attachment’ y ‘image_resize’. Se ahorraría tiempo al evitar generar los thumbnails.

 

El ejemplo más sencillo es simplemente importar los datos de un fichero concreto:

Para que la importación funcione es necesario que tengas instalado y activado el plugin WordPress Importer. Puedes instalarlo y activarlo directamente desde la línea de comandos:

Puede que también te interese

WP-CLI Parte 8, Scaffold: genera esqueletos de código para post types, taxonomías, plugins, child themes…
WP-CLI Parte 8, Scaffold: genera esqueletos de código para post types, taxonomías, plugins, child themes…
1. Instalación y primeros pasos 2. Instalando WordPress y primeros pasos y configuraciones 3. Trabajando con posts 4. Trabajando con usuarios 5. Trabajando con la…
Añadir un icono personalizado a nuestro custom post type
Añadir un icono personalizado a nuestro custom post type
La versión 3.8 de WordPress trajo consigo nuevas mejoras, el tema Twentyfourteen, y un cambio completo de diseño en el Back End. Con éste cambio,…
Mejora la puntuación de Google PageSpeed Insights: Eliminar el CSS que bloquea la visualización del contenido de la mitad superior de la página
Mejora la puntuación de Google PageSpeed Insights: Eliminar el CSS que bloquea la visualización del contenido de la mitad superior de la página
1. Optimizar imágenes 2. Minificar CSS y JS 3. Especificar caché de navegador 4. Habilita la compresión 5. Reducir el tiempo de respuesta del servidor…
Cómo solucionar el error interno del servidor en WordPress
Cómo solucionar el error interno del servidor en WordPress
Otro de los errores más comunes o que con más frecuencia nos podemos encontrar, es el error interno del servidor ó error 500. Se identifica claramente…