Dic 08

Org-mode : Tablas

Tag: basicoverdrive @ 2:23 pm

Debido a la extension de org-mode y la importancia que esta teniendo con todo el proceso activo de desarrollo, he decidido dividir el post de org-mode segun el tema tratado. En este primer post hablare de como trabajar con tablas en org-mode.

Definicion de tablas

Las tablas en org-mode se tratan en ASCII plano, cada linea que comience por ‘|‘ (pipe) sera considerada parte de una tabla. Dicho simbolo se considerara el separador de columna. Las tablas son re-alineadas cada vez que se pulsa TAB o INTRO o C-c C-c dentro de la tabla. TAB tambien se emplea para moverse al siguiente campo e INTRO para moverse a la siguiente columna.

Para crear una tabla debemos escribir por ejemplo:

|Name|Phone|Age|
|-

Y pulsar TAB para crear la tabla o bien se puede escribir directamente |Name|Phone|Age y presionar C-c INTRO.

DEL y Backspace se emplean para eliminar campos. S-TAB o INTRO se emplean para dejar el campo en blanco.

Creacion

  • C-c | : Convierte una region activa en una tabla, tomando los TAB como separaciones o usando CSV, en caso de no encontrar ninguno de los dos usara los espacios como separador.
  • C-u C-c | : Fuerza el uso de CSV.
  • C-u C-u C-c | : Fuerza el uso de TAB.
  • C-numero C-c | : Fuerza el uso de un numero determinado de espacios.

    Alineacion

    • C-c C-c : Re-alinea una tabla sin mover el cursor.
    • TAB : Re-alinea una tabla, moviendo el cursor al siguiente campo creando una nueva fila si es necesario.
    • S-TAB : Re-alinea una tabla moviendose a la fila anterior.
    • INTRO : Re-alinea una tabla y se desplaza a la siguiente fila creando una nueva fila si es necesario o separando una tabla en dos si se efectua entre dos filas.
    • M-a : Se desplaza al campo anterior.
    • M-e : Se desplaza al siguiente campo.

      Edicion de filas y columnas

      • M-<– o M–> : Se desplaza una columna a la izquierda/derecha.
      • M-S-<– : Elimina la columna actual.
      • M-S—> : Inserta una nueva columa a la derecha del cursor.
      • M-up o M-down : Se desplaza a la fila anterior/posterior.
      • M-S-up : Elimina la fila actual.
      • M-S-down : Inserta una nueva fila sobre la fila actual. Si se emplea con el prefijo, la creara debajo.
      • C-c – : Inserta una linea horizontal para la fila actual. Si se emplea con el prefijo insertara la linea horizontal encima de la linea actual.
      • C-c INTRO : Inserta una linea horizontal debajo de la fila actual y mueve el cursor a dicha fila.
      • C-c ^ : Ordena la region de una tabla (alfabeticamente, numericamente o por fecha). Si es llamado con un argumento lo hara case-sensitive.

      Regiones

      • C-c C-x M-w : Copia una region de una tabla e ignora los puntos y marcas que determinan la tabla. ‘Copiar’.
      • C-c C-x C-w : Copia una region de una tabla y deja en blanco todos los campos del rectangulo. ‘Cortar’.
      • C-c C-x C-y : Pega una region en una tabla y redimensiona la tabla si es necesario. ‘Pegar’.
      • M-INTRO : Ajusta en distintas lineas columnas que excedan el ancho. Si se realiza sobre una region el texto sera ajustado a la region minima del ancho dado especificando un numero de filas deseadas mediante prefijos. Si se realiza fuera de una region el campo actual sera dividido en la posicion donde se encuentre el cursor o bien si se realiza fuera de una region y usando prefijos dejara el campo en blanco y el contenido del mismo quedara en el campo previo.

      Calculos

      • C-c + : Suma los numeros de la columna actual, de un rectangulo definido o bien de una region activa, el resultado es mostrado en ‘echo area’ o minibuffer y puede ser insertado con C-y.
      • S-INTRO : Cuando el campo actual esta vacio, copia desde el primero que no lo esta, si no esta vacio copiara el campo actual. Lo pegara en la siguiente fila y movera el cursor a ella. Valores enteros seran incrementados durante dicha copia (campos autonumericos) excepto si son demasiado grandes. Usando argumentos con prefijo 0 deshabilitara el incremento.

      Miscelanea

      • C-c ` : edita el campo actual en una ventana distinta. Usando el prefijo C-u hara que se vea el campo de forma completa.
      • M-x org-table-import : importa una tabla de un fichero. La tabla debe usar TAB o espacios como separadores.
      • C-c | : importa una tabla usando pegado de texto tabular (C-x C-x).
      • M-x org-table-export : exporta una tabla a un fichero. La tabla usara el TAB por defecto como separador.

      Para deshabilitar el editor automatico de tablas podemos anadir a nuestro .emacs:

      (setq org-enable-table-editor nil)

      De aqui en adelante solo C-c C-c hara una re-alineacion manual.

      Columnas estrechas

      El ancho de la columna es determinado por el editor de tablas. Para limitar el ancho de una columna debemos tener un campo llamando ‘<N>‘ donde N es el ancho maximo de caracteres por columna. Las columnas que sean mas anchas se acortaran y anadiran «=>» indicando que hay mas texto, que podra ser mostrado mediante C-c ` (que edita) o mediante un tooltip. Para salir de la edicion deberemos pulsar C-c C-c.

      Podemos colocar alineacion automatica al inicio medinate org-startup-align-all-tables o en el fichero de arranque mediante:

      #+STARTUP: align
      #+STARTUP: noalign

      Grupos de columnas

      Es posible usar tipos especiales de columnas y agruparlos si la primera columna comienza por ‘/‘ para indicar que queremos agrupaciones; ‘<‘ indicara el inicio de grupo, ‘>‘ el final del grupo, ‘<>‘ indica su propio grupo (uno solo).

      Org-table como modo menor

      Tan solo debemos anadir a nuestro .emacs:

      (add-hook ‘mail-mode-hook ‘turn-on-orgtbl)

      Esto tiene utilidad si queremos construir por ejemplos tablas mediante el uso de LaTeX, etc… pudiendo asi combinar un modo mayor para un lenguaje o similar al mismo tiempo que se usan tablas de org como modo menor.

      3 Responses to “Org-mode : Tablas”

      1. GNU/Emacs » Org-mode : TAGS (etiquetas) says:

        […] que este articulo es interesante combinarlo con los anteriores referentes a org-mode (tablas, hiperenlaces y […]

      2. GNU/Emacs » Org-mode : spreadsheet (hojas de calculo) says:

        […] las hojas de calculo se emplean mediante dicho uso, por lo que es necesario leer el articulo sobre Org-mode: tablas para poder aplicar luego hojas de calculo sobre […]

      3. GNU/Emacs » Org-mode: propiedades y columnas says:

        […] areas, que luego veremos que utilidad tiene. Para entender este post es necesario entender como trabajar con tablas en org-mode y como crear listas en org-mode (relacionadas o no con las tareas o TODO). Es posible asignar […]

      Leave a Reply

      You must be logged in to post a comment.