Dic 10 2009

Org-mode : TODO (Tareas)

Tag: basicoverdrive @ 4:01 am

En Org tenemos opcion para almacenar y manejar listas de cosas a realizar (aka TODO), como marcar y mostrar dichas entradas, asignaciones y flujos de trabajos, fechas y notas del progreso, marcar prioridades, division de tareas por partes, etc.

Cualquier headline (a partir de ahora lo llamaremos linea de cabecera) se convertira en una tarea a realizar si se le precede de la palabra TODO:

*** TODO Leer onLisp

Aqui podemos aplicar distintos tipos de keystrokes interesantes:

  • C-c C-t : Rota el estado de TODO (pasando por unmarked, TODO, DONE). La misma rotacion es aplicacada mediante buffers de agenda y lineas de tiempo presionando la tecla t.
  • C-u C-c C-t : selecciona una palabra especifica usando autocompletion. Despues necesitamos asignar teclas a estados de TODO.
  • S–> o S-<- : Selecciona el siguiente o anterior estado de TODO.
  • C-c C-v o C-c / t : Muestra la lista de elementos de TODO en un arbol. Carpetas muestran el buffer entero, y muestra todos los elementos con sus cabeceras de forma jerarquica sobre el mismo. Se puede usar argumentos de prefijo dando una lista tal como KWD1|KWD2|… para listar entradas relacionadas, con prefijos numericos, mostrara el arbol Nth. Con dos prefijos, buscara en todos los TODO y entradas marcadas como DONE.
  • C-c a t : Muestra la lista global de TODO.
  • S-M-INTRO : Inserta una nueva entrada debajo del TODO actual.

Estados

Podemos usar claves de forma *secuencial* para estados de un trabajo en proceso:

(setq org-todo-keywords ‘((sequence «TODO» «FEEDBACK» «VERIFY» «|» «DONE» «DELEGATED»)))

La barra vertical o pipe diferenciaria de estados que requieren accion de los que no necesitan futura accion. Si no se provee de dicho pipe, la tarea estara por defecto ‘terminada’. Aqui podriamos aplicar comandos como:

  • C-c C-t para rotar el estado como explicamos anteriormente, aunque podriamos usarlo con el prefijo para dejarlo en un estado directamente como:
  • C-3 C-c C-t : Rota el estado directamente al tercero

Podemos usar claves para indicar un tipo de trabajo que se realizara a quien se le asignara, y cuando este terminado marcada como DONE, aqui C-c C-t se usara para reasignar la tarea a otra persona, pero si se vuelve a lanzar C-c C-t pasara de cualquier persona directamente al estado DONE, tambien se pueden usar prefijos para saltar directamente a cualquier persona:

(setq org-todo-keywords ‘((type «Fred» «Sara» «Lucy» «|» «DONE»)))

En dicho tipo de lista, podremos ver que tareas tiene asignadas la tercera persona (Lucy) mediante C-3 C-c C-v de dicho buffer, si queremos verlo a modo global podemos usar C-3 C-c t.

Para tener distintas propiedades para una tarea, es decir multiples claves podemos hacer algo asi:

(setq org-todo-keywords
‘((sequence «TODO» «|» «DONE»)
(sequence «REPORT» «BUG» «KNOWNCAUSE» | «FIXED»)
(sequence «|» «CANCELLED»)))

En este caso C-c C-t solo operara entre subsecuencias. Mientras que C-u C-u C-c C-t ó C-S–> saltara entre estados dentro de una subsecuencia. S-<– y S–> se desplazara por todas las propiedades de todas las subsecuencias.

Acceso Rapido

Tambien podemos crear ‘acceso rapido’ o ‘acceso directo’ a los estados mediante el siguiente ejemplo:

(setq org-todo-keywords
‘((sequence «TODO(t)» «|» «DONE(d)»)
(sequence «REPORT(r)» «BUG(b)» «KNOWNCAUSE(k)» «|» «FIXED(f)»)
(sequence «|» «CANCELLED(c)»)))

Presionando C-c C-t <letra> saltara directamente a dicho estado. Con SPC directamente se eliminara cualquier clave TODO de la lista.

Estados espeficios para ficheros individuales

Para ello debemos dejar la primera linea del fichero tal que asi:

#+TODO: TODO FEEDBACK VERYFY | DONE CANCELED

Tambien podemos especificar el tipo de tarea a quien sera asignada de manera especifica asi:

#+TYPE_TODO Fred Sara Lucy Mike | DONE

O bien especificar distintas propiedades en paralelo para una tarea medianta:

#+TODO: TODO | DONE
#+TODO: REPORT BUG KNOWNCAUSE | FIXED
#+TODO: | CANCELED

Si usamos abbrev es decir (M-TAB) cuando escribamos #+ podemos usar el completion para asegurarnos de que lo escribimos correctamente.

Resaltado

Es posible resaltar los elementos dependiendo del estado del elemento. Por ejemplo:

(setq org-todo-keyword-faces
‘((«TODO»        . org-warning)
(«DEFERRED»    . shadow)
(«CANCELED»    . (:foreground «blue» :weight bold))))

Dependencias

Podemos crear estructuras mas complejas con dependencias y con ello crear listas y herencias, creando subtareas (hijos) bloqueando asi la padre u otras hermanas, por ejemplo:

* TODO Blocked until (two) is done
** DONE one
** TODO two

* Parent
:PROPERTIES:
:ORDERED: t
:END:
** TODO a
** TODO b, needs to wait for (a)
** TODO c, needs to wait for (a) and (b)

Para que ello surta efecto es necesario configurar el valor de la variable org-enforce-todo-dependencies. Y con los siguientes keybindings podemos hacer:

  • C-c C-x o : hace toggle de la propiedad ORDERED de la entrada actual. Si se quiere trazar el valor de dicha propiedad con un tag para tener mejor visibilidad debemos configurar la variable org-track-ordered-property-with-tag.
  • C-u C-u C-u C-c C-t : Cambia el estado de la lista de tareas, de cualquier estado a blocante.

Ademas configurando la variable org-agenda-dim-blocked-tasks, la lista de tareas no podra ser cerrado debido a las dependencias y sera invisible o mostrando en la agenda.
Tambien se pueden usar checkboxes para bloquear dicha lista mediante la variable org-enforce-todo-checkbox-dependencies, por lo que bloqueara el poder cambiar el estado a DONE.

Para mas complejidad en dependencias se puede revisar el modulo org-depend.el.

Archivando trabajos por tiempo

Se puede archivar usando la fecha:

(setq org-log-done ‘time)

O bien mediante una nota con dicha fecha (se debe crear una entrada en la cabecera con Closing Note):

(setq org-log-done ‘note)

Trazando cambios de estado

A la hora de ver dichos cambios es posible modificar la vista modificando la variable org-log-into-drawer asignandole el valor LOGBOOK (recomendado) o en forma de subarbol dandole el valor de LOG_INTRO_DRAWER.

Se usan ‘marcas‘ especiales para acortar la configuracion de las tazas, como ‘!‘ para timestamp y ‘@‘ para notas, por ejemplo:

(setq org-todo-keywords
‘((sequence «TODO(t)» «WAIT(w@/!)» «|» «DONE(d!)» «CANCELED(c@)»)))

Tambien podemos usar las mismas preferencias locales a un buffer:

#+TODO: TODO(t) WAIT(w@/!) | DONE(d!) CANCELED(c@)

Para guardar todas estas transiciones podemos usar LOGGING, sin embargo una linea indicando :LOGGING: nil causara que no loguee ninguna transicion:

* TODO Loguear cada estado con su fecha y hora
:PROPERTIES:
:LOGGING: TODO(!) WAIT(!) DONE(!) CANCELED(!)
:END:
* TODO Solo loguear la transicion a WAIT y cuando se repita esta
:PROPERTIES:
:LOGGING: WAIT(@) logrepeat
:END:
* TODO No loguear nada
:PROPERTIES:
:LOGGING: nil
:END:

Tazando los habitos

Para trazar los habitos debemos primero configurar la variable org-modules, el habito es TODO, usando la palabra clave TODO representando el estado de la tarea abierta. La propiedad STYLE debe tener el valor habit. Cada tarea puede ser repetitiva como por ejemplo afeitarse y se puede realizar por ejemplo con un minimo de 2 dias pero no mas de 4, eso lo indicamos con la sintaxis ‘.+2d/4d‘ y ademas queremos guardar un logging cada vez que finalicemos la tarea de forma historica, por ejemplo quedaria asi:

** TODO Afeitarse
SCHEDULED: <2009-10-17 Sat .+2d/4d>
… aqui se iran anadiendo entradas automaticamente …
:PROPERTIES:
:STYLE:    habit
:LAST_REPEAT: [2009-10-19 Mon 00:36]
:END:

Esto usara los siguientes colores:

Azul -> si la tarea se finalizo otro dia
Verde -> Si la tarea se ha finalizado hoy
Amarillo -> Si la tarea es para manana como muy tarde
Rojo -> Si la tarea es para hoy como muy tarde

Se pueden modificar algunas variables interesantes para mostrar los habitos en la agenda:

  • org-habit-graph-column : La columna del buffer con que consistencia debe ser grabado el grafico.
  • org-habit-preceding-days : El historial maximo.
  • org-habit-following-days : Numero de dias que debe seguir apareciendo una tarea despues de ser realizada.
  • org-habit-show-habits-only-for-today : Si no es nil, mostrara solo los habitos de la agenda de hoy.

Ademas presionando K en la agenda, desabilitaremos/habilitaremos temporalmente los habitos.

Prioridades

Es posible prioridad tareas mediante:

*** TODO [#A] Escribir una carta a Richard Stallman

Por defecto Org permite 3 prioridades (A, B y C) siendo A la maxima prioridad. Las prioridades se reflejan solo en la agenda, fuera de ella no tienen efecto.

  • C-c , : Le asigna la prioridad a la tarea actual (A, B o C). Si se pulsa SPC la prioridad es eliminada. Las prioridades tambien pueden ser modificadas remotamente desde la agenda.
  • S-flechaarriba : Incrementa la prioridad.
  • S-flechaabajo : Decrementa la prioridad.

Se pueden modificar la posibles prioridades modificando las variables org-highest-priority, org-lowest-priority y org-default-priority.

Para modificar las prioridades de una tarea de un buffer individual se puede hacer mediante:

#+PRIORITIES: A C B

Rompiendo una tarea en subtareas

Podemos coger una tarea compleja y dividirla en subtareas, viendo asi la progresion respecto al total, para ello usaremos [/] ó [%]. Estas cookies actualizaran su estado cuando una subtarea cambie de estado o bien cuando se pulse C-c C-c en la cookie:

* Organize Party [%]
** TODO Llamar a gente [/]
*** TODO Peter
*** DONE Sarah
** TODO Comprar comida
** DONE Hablar con el vecino

Si queremos guardar las estadisticas de un subarbol de tareas (no directamente del hijo) debemos configurar la variable org-hierarchical-todo-statistics. Para realizar esto en un subarbol simlpe debemos incluir la palabra ‘recursive‘ como valor de la propiedad COOKIE_DATA:

* Parent capturing statistics [/]
:PROPERTIES:
:COOKIE_DATA: todo recursive
:END:

Si queremos cambiar automaticamente a DONE la tarea cuando todas las tareas hijas hayan finalizado:

(defun org-summary-todo (n-done n-not-done)
«Switch entry to DONE when all subentries are done, to TODO otherwise.»
(let (org-log-done org-log-states)
(org-todo (if (= n-not-done 0) «DONE» «TODO»))))

En caso de tener muchas subtareas es conveniente usar checkboxes.

Checkboxes

Cada tarea puede ser mostrada usando un checkbox, tan solo debemos crear [ ]. Para hacer toggle en una tarea de checkbox debemos usar C-c C-c o directamente usar el raton ya que es clickable, aqui un ejemplo de checkbox:

* TODO Organizar fiesta [/]
– [ ] Llamar a gente [/]
– [ ] Peter
– [ ] Sarah
– [ ] Sam
– [ ] Pedir comida
– [ ] Preparar la musica
– [ ] Hablar con los vecinos

Si las tareas deben efectuarse en secuencia obligatoria, los checkboxes deben deshabilitarse para evitar problemas y comportamientos no deseados. Los siguientes comandos funcionan con checkboxes:

  • C-c C-c : Hace toggle de una tarea en checkbox (ademas las estadisticas del headline se actualizaran).
  • C-c C-x C-b : Hace toggle de una tarea en checkbox (tambien funciona para regiones, ademas puede usar argumentos/prefijo en dichas regiones).
  • M-S-RET : Inserta una nueva tarea de tipo checkbox. (realmente es M-Ret).
  • C-c C-x o : Hace toggle de ORDERED si deben ser las tareas ejecutadas en secuencia. Si queremos trazar estos tipos de tareas ademas debemos configurar la variable org-track-ordered-property-with-tag.
  • C-c # : Actualiza las estadisticas de la entrada actual. Si es ejecutada con argumentos/prefijo C-u, actualizara el fichero entero.
  • M-<flecha arriba> : Mueve un elemento de la lista hacia arriba.
  • M-<fleha abajo> : Mueve un elemento de la lista hacia abajo.
  • C-u C-c ! : Anadira un timestamp donde nos escontremos.
  • C-c C-t : Aplicara un timestamp para el headline si incluimos las siguiente linea en nuestro .emacs:

(setq org-log-done ‘time)


Dic 09 2009

Org-mode : Hiperenlaces

Tag: basicoverdrive @ 1:45 am

Org permite guardar enlaces y que sean accesibles de forma click-able. El formato general es:

[[link][descripcion]        alternativa          [[link]]

Una vez todos los corchetes esten presentes, la descripcion sera mostrada, asi como el enlace. La forma que se usa para resaltarlos es mediante la variable org-link, que por defecto es subrayado. Es posible modificar tanto el link como su descripcion pulsando las teclas C-c C-l. Para borrar el enlace tan solo debemos poner el cursor al principio de la linea y pulsar BACKSPACE.

Enlaces internos

El link puede ser interno (y no una URL) para ello debemos crear identificadores y ser responsables de mantener un unico identificador diferente para cada enlace interno, por ejemplo si anadimos esta linea:

# <<<Mi objetivo>>>

Podremos referenciar a dicho enlace interno creando lo siguiente:

[[Mi objetivo]]

o bien

[[Mi objetivo]][[Buscar mi objetivo]]

Para acceder a los enlaces debemos presionar C-c C-o o bien hacer click con el raton. Tambien es posible exportarlos como enlaces HTML mediante HTML export (el cual comentaremos mas adelante).

Si el enlace no existe como tal, org buscara enlaces que comiencen por el mismo patron (es decir *Mi objetivo) y mostrara los resultados solo si coincide completamente, pudiendo acceder a cada uno de ellos o bien volviendo atras mediante C-c &.

Es posible crear enlaces usando botones de radio mediante (solo seran cargados cuando se cargue el fichero org la primera vez o bien pulsando C-c C-c):

<<<Mi objetivo>>>

Enlaces externos

Org permite enlazar a ficheros, webs, usenet, mails, entradas de bases de datos, e incluso conversaciones de irc o sus logs. Todos los enlaces externos comienzan por la palabra clave que identifica el tipo de enlace externo seguido por los dos puntos y el propio enlace, por ejemplo:

http://www.blackhats.es/    Una web
file:/home/overdrive/org.txt    Un fichero con PATH absoluto
/home/overdrive/org.txt        Igual que arriba
file:documentos/ultimo.pdf    Un fichero con PATH relativo
./documentos/ultimo.pdf        Igual que arriba
file:alguntexto::NNN        Una linea donde saltar dentro de un fichero
file:projects.org        Enlace a otro fichero org
file:projects.org::foo bar    Busqueda de texto en un fichero org
file.projects.org::*task bar    Busqueda de cabecera en un fichero org
id:B742456-2EAS-4FGHDF-345BZ    Enlace a un identificador
news:comp.emacs            Enlace a usenet
mailto:zoom@blackhats.es    Enlace a un correo
vm:carpeta            Enlace VM a una carpeta
vm:carpeta#id            Enlace VM a un mensaje
vm://yo@al.site.org/carpeta#id     Enlace VM a un identificador de una maquina remota
wl:carpeta            Enlace WANDERLUST a una carpeta
wl:carpeta#id            Enlace WANDERLUST a un id de una carpeta
mhe:carpeta            Enlace MH-E a una carpeta
mhe:carpeta#id            Enlace ME-E a un id de una carpeta
rmail:carpeta            Enlace rmail a una carpeta
rmail:carpeta#id        Enlace rmail a un id de una carpeta
gnus:grupo            Enlace gnus a un grupo
gnus:grupo#id            Enlace gnus a un id de un grupo
bbdb:R.*Stallman        Enlace BBDB con expresion regular (regexp)
irc:/freenode.net/#emacs/over    Enlace IRC
shell:ls *.org            Enlace a un comando shell
elisp:org-agenda        Enlace a un comando interactivo Elisp
elisp:(find-file-other-frame «elisp.org»)   Enlace a un formulario lisp a evaluar

Los enlaces deben ser cerrados con doble corchete y deben contener un texto descriptivo en lugar de mostrar la URL:

[[http://www.gnu.org/software/emacs/][GNU Emacs]]

Es posible poner como descripcion una URL o una imagen que luego puede ser mostrada inline. Ademas para evitar problemas con espacios o ciertas palabras reservadas es posible mediante el entrecomillado simple por ejemplo:

‘bbdb:Richard Stallman’

Administracion

C-c l : Si queremos insertar un enlace (ya sea para buffers, VM, rmail, Wanderlust, MH-E, gnus, navegadores como W3 o W3M, contactos BBDB, irc, agenda u otros ficheros).
C-c C-l : Inserta un enlace de forma interactiva sobre el cursor (permitiendo usar autocompletion con TAB)
C-u C-c C-l : Inserta un enlace usando fichero que sera insertado.
C-c C-o ó RET : Abre un enlace.
C-u C-u C-c C-o : Abre un enlace evitando emacs.
C-c % : Mete la posicion actual en el mark-ring.
C-c & : Salta a una posicion guardada.
C-c C-x C-n : Se desplaza al siguiente enlace en el buffer.
C-c C-x C-p : Se desplaza al enlace anterior en el buffer.

Se puede bindear a C-n y C-p anadiendo las siguientes lineas en nuestro .emacs:

(add-hook ‘org-load-hook
(lambda ()
(define-key ‘org-mode-map «\C-n» ‘org-next-link)
(define-key ‘org-mode-map «\C-p» ‘org-previous-link)))

Usando enlaces

Se pueden insertar las siguientes lineas en nuestro .emacs para acceder a los enlaces fuera de org:

(global-set-key «\C-c L» ‘org-insert-link-global)
(global-set-key «\C-c o» ‘org-open-at-point-global)

Abreviaturas

Se pueden usar abreviaturas para evitar tener que escribir mas de la cuenta, por ejemplo:

[[linkword:tag][descripcion]]

Donde ‘tag‘ es opcional y linkword debe ser un caracter alfanumberico o ‘_‘ o ‘‘. En lugar de tener que repetir dicha linea muchas veces podemos hacer cosas como:

(setq org-link-abbrev-alist
‘((«bugzilla» . «http://10.1.2.9/bugzilla/show_bug.cgi?id=»)
(«google»   . «http://www.google.com/search?q=»)
(«ads»         . «http://adsabs.harvard.edu/cgi-bin/nph-abs_connect?author=%s&db_key=AST»)))

Para el primer caso podemos enlazar un bug con [[bugzilla:129]], para el segundo caso podriamos usar [[google:OrgMode]] y para el ultimo caso podriamos usar [[ads:Dominik,C]] que reemplazara el contenido la cadena ‘%s‘ por el tag.

Para realizar abreviaturas para un fichero especifico podemos usar:

#+LINK: bugzilla http://10.1.2.9/bugzilla/show_bug.cgi?id=
#+LINK: google     http://www.google.com/search?q=%s

Ademas es posible usar completion para abreviaturas despues de escribir ‘[‘.

Opciones de busqueda

Los enlaces pueden contener cierta informacion a la hora de saltar en un enlace particular, como por ejemplo el numero de linea, una expresion regular, etc… por ejemplo:

[[file:~/codigo/main.c::255]]
[[file:~/xx.org::My objetivo]]
[[file:~/xx.org::*My objetivo]]
[[file:~/xx.org::/expresion_regular/]]

Busquedas personalizadas

Es posible modificar y personalizar las busquedas para buscar enlaces en ficheros con una extension particular hookeando variables como org-create-file-search-functions y org-execute-file-search-functions, tambien es interesante ver el mecanismo que usa org-mode para buscar en bases de datos BibTeX, para ello es posible ver la implementacion en org-bibtex.el.


Dic 08 2009

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.


      Página siguiente »