martes, 23 de noviembre de 2010

VIM: Comandos Utiles en VIM II

En la entrada anterior ingrese algunos comandos esenciales para la utilización de VIM, hoy ampliaremos la cantidad de comandos que se pueden utilizar en este editor de texto.
  • dd : Borra la linea en la cual esta ubicado el cursor.
  • r : Remplaza el caracter sobre el cual esta posicionado el cursor.
  • ~ : Remplaza el caracter sobre el cual esta posicionado el cursor por una mayúscula si el caracter estaba en minúscula o a minúscula si el caracter estaba en mayúscula.
  • u : Deshace el ultimo cambio realizado en el documento.
  • [ctrl]+r : Rehace el ultimo cambio desecho.
  • Y : Copia el contenido de la línea en la cual se encuentra el cursor.
  • p : Pega el ultimo elemento cortado o copiado, es decir, se puede copiar la ultima linea borrada con "dd" o la ultima línea copiada con "Y". Es importante mencionar que esta copia se realiza en la línea siguiente a la ubicación actual de cursor.
  • G : Permite ir a la primera posición de la ultima línea del documento.
  • 1G : Permite ir a la primera posición de la primera línea del documento.
  • w : Permite avanzar desde una palabra al inicio de la siguiente palabra, es decir, se puede avanzar de una palabra a otra. "W" tiene el mismo efecto.
  • b : Permite retroceder desde una palabra al inicio de la misma palabra, es decir, se puede retroceder de una palabra a otra. "B" tiene el mismo efecto.
  • m : Crea una marca en el documento al inicio de la linea donde se encuentra el cursor. Ej. ma, esa posición queda marcada y el nombre de la marca es a.
  • ' : Permite regresar a la ubicación de una marca creada con anterioridad. Ej. 'a, se accede a la posición que contiene la marca a.
Este editor también permite realizar búsquedas sobre el documento, para esto se debe utilizar el caracter "/".
  •  /frase_buscada : Permite realizar una búsqueda sobre el documento.
  • n : Permite acceder a la siguiente posición donde se encuentra la palabra o frase buscada.
  • N : Permite acceder a la posición anterior donde se encuentra la palabra o frase buscada.
Es importante mencionar que VIM también permite realizar búsquedas con expresiones regulares.

Como se mencionó en la entrada anterior también se puede ejecutar comandos antecedidos por ":", a continuación se agregan nuevos comandos.
  • :%s/frase_buscada/frase_nueva/g : Permite sustituir una frase por otra en todo el documento. El "%" indica que la búsqueda se debe realizar en todo el documento, la "s" indica que la operación que se realizará es de sustitución, entre el primer y segundo "/" se ingresa la frase que se buscará, entre el segundo y el tercer "/" se ingresa la frase nueva y la "g" al final de la línea indica que si la frase se encuentra más de una vez en una línea, se remplaza todas las veces que se encuentre. Este comando también permite dividir la línea en varias partes, entregando la posibilidad de mezclar o acomodar el texto contenido en las líneas que cumplen con el patrón ingresado, como se puede observar en el siguiente ejemplo.
Ej.

Contenido Inicial del Archivo en VIM

 INSERT INTO `tabla` (`id`, `campo_1`, `campo_2`, `campo_3`, `campo_4`, `campo_5`, `campo_6`,  `campo_7`, `campo_8`, `campo_9`, `campo_10`, `campo_11`, `campo_12`, `campo_13`, `campo_14`) VALUES
(3708364, '61654760', '6609
61654760', 8, '', '0000-00-00 00:00:00', '', 2, '192.168.77.213', '7770', 'pahaoanae', 'dato_11', 'dato_12', NULL, NULL),
(3708362, '90
654795', '660990654795', 8, '', '0000-00-00 00:00:00', '', 2, '192.168.77.213', '7770', 'pahaoanae', 'dato_11', 'dato_12', NULL, NULL),

Expresión Regular para remplazar conservando algunos contenidos

 :%s/\(([0-9]*, '\)\([0-9]\)\([0-9]*\)\('.*'\)pahaoanae\('.*\),/\1\2\3\4\2-\3\5/

Contenido Final del Archivo en VIM

 INSERT INTO `tabla` (`id`, `campo_1`, `campo_2`, `campo_3`, `campo_4`, `campo_5`, `campo_6`,  `campo_7`, `campo_8`, `campo_9`, `campo_10`, `campo_11`, `campo_12`, `campo_13`, `campo_14`) VALUES
(3708364, '
61654760', '660961654760', 8, '', '0000-00-00 00:00:00', '', 2, '192.168.77.213', '7770', '6-1654760', 'dato_11', 'dato_12', NULL, NULL)
(3708362, '
90654795', '660990654795', 8, '', '0000-00-00 00:00:00', '', 2, '192.168.77.213', '7770', '9-0654795', 'dato_11', 'dato_12', NULL, NULL)

Aquí se debe indicar que todo lo que se encuentra entre los paréntesis antecedidos por el carácter de escape "\(...\)", en este caso los tres puntos, serán almacenados en la variable \1, siempre que sea el primer paréntesis utilizado, los siguientes continuarán con \2, \3 hasta un máximo de \9 variables.
  • :'a,'bs/frase_buscada/frase_nueva/g : Permite sustituir una frase por otra en el documento, entre dos marcas. Las "'a,'b" indica que la búsqueda se debe realizar entre las marcas "a" y "b" del documento, la "s" indica que la operación que se realizará es de sustitución, entre el primer y segundo "/" se ingresa la frase que se buscará, entre el segundo y el tercer "/" se ingresa la frase nueva y la "g" al final de la línea indica que si la frase se encuentra más de una vez en una línea, se remplaza todas las veces que se encuentra.
  • :'a,'bd : Se borran todas las líneas ubicadas entre las marcas "a" y "b". Las marcas "'a,'b" indica que las líneas que serán eliminadas deben estar entre las marcas "a" y "b", la letra "d" indica que la operación que se realizará es eliminar las líneas.
  • :set nosmartindent : Elimina la autoindexación en el documento.
  • :set smartindent: Agrega la autoindexación en el documento.

    "Gracias, por compartir tus conocimientos"

    lunes, 22 de noviembre de 2010

    VIM: Comandos Utiles en VIM

    La gran mayoría de los sistemas operativos basados en Linux contienen el editor de texto llamado VIM, para muchos parece muy complicado de utilizar, pero esto también le permite ser muy potente en la edición de texto.

    Antes de escribir algunos comandos que consideró que son muy útiles debo hacer mención que este editor de texto se separa en dos entornos donde se encuentra el cursor, el primero es el modo donde se pueden ingresar los comandos, para llegar a este entorno se debe presionar la tecla "Esc". El otro entorno es donde se puede editar el texto. A continuación se mencionaran algunos comandos que pueden ser útiles para comenzar a trabajar con VIM.

    • i : permite ingresar texto en la posición anterior a la cual se encuentra ubicado el cursor.
    • a : permite ingresar texto en la posición posterior a la cual se encuentra ubicado el cursor.
    • I : permite ingresar texto al inicio de la línea.
    • A : permite ingresar texto al final de la línea.
    • o : permite ingresar texto al inicio de la línea siguiente.
    • x : permite eliminar el caracter del documento sobre el cual se encuentra el cursor (la tecla "Supr" o "Del" tiene el mismo efecto).
    Los comandos descritos anteriormente deben ser ingresados cuando se esta en modo comando, es decir, después de presionar la tecla "Esc". Para ejecutar algunos comandos en VIM después de presionar la tecla "Esc" se debe presionar antes la tecla ":" (dos puntos). A continuación se muestran algunos de estos comandos.
    • :w : permite guardar el contenido del archivo.
    • :q : permite salir del documento.
    • :q! : permite salir del documento, sin guardar los cambios que se han realizado.
    Esos comando permiten realizar ediciones de texto muy básicas, pero son el punto de partida para trabajar con VIM.

    "Gracias, por compartir tus conocimientos"

    martes, 9 de noviembre de 2010

    PostgreSQL: Extraer los campos de una fecha

    Uno de los recursos más almacenados en las bases de datos son las fecha, existiendo ocasiones en las cuales se deben obtener algunos campos de la fecha, para este ejemplo se utilizará la tabla personas creada como se observa a continuación:

    create table personas (
       id                     SERIAL      NOT NULL,
       rut                   varchar(15) NULL,
       nombre           varchar(30) NULL,
       apaterno         varchar(30) NULL,
       amaterno        varchar(30) NULL,
       fecha_nac        date   NULL,
       hora_nac         time NULL,
       sexo                 varchar(1)  NULL,
       direccion         varchar(30) NULL,
       ciudad             varchar(30) NULL,
       telefono           integer     NULL,
       created            timestamp   NOT NULL,
       modified          timestamp   NULL,
       constraint pk_personas primary key (id)
    );

    De esta tabla se rescataran cada uno de los campos de la creación del registro por separados y a demás se obtendrá el día de la semana al que corresponde la fecha de creación del registro.

    SELECT
     rut,
     extract(year from created)::int as anyo,
     extract(month from created)::int as mes,
     extract(day from created)::int as dia,
     extract(hour from created)::int as hour,
     extract(minute from created)::int as minuto,
     extract(second from created)::int as segundo,
     CASE extract(dow from created)
      WHEN 0 THEN 'Domingo'
      WHEN 1 THEN 'Lunes'
      WHEN 2 THEN 'Martes'
      WHEN 3 THEN 'Miercoles'
      WHEN 4 THEN 'Jueves'
      WHEN 5 THEN 'Viernes'
      WHEN 6 THEN 'Sabado'
     END
     as dow
    FROM
     personas
    ;

    Con esta consulta se obtiene toda la fecha de creación desglosada completamente, a demás permite obtener el día de la semana en que fue creado utilizando el CASE que permite seleccionar entre los valores el valor obtenidos y lo convierte en una cadena con el nombre del día.

    extract(campo from fuente)

    Recupera los valores de una fecha/hora, donde la fuente es un campo del tipo de dato fecha/hora, en este caso en particular un timestamp, mientras que el campo es el tipo de valor recuperado de la fecha, los campos existentes en las variables de fecha/hora son los siguientes:
    • century: devuelve el siglo de la fecha, no existe siglo 0, solo existe desde el -1 al 1. Ej. el año 2000 es el siglo 20, mientras que el año 2001 es el siglo 21.
    • day: devuelve el día del mes, va desde el 1 al 31 según el mes que corresponda.
    • decade: divide el campo del año en 10. Ej. el año 2001 sería la decada 200.
    • dow: devuelve el día de la semana que va desde 0 a 6, donde el 0 corresponde al domingo.
    • doy: devuelve el día del año que va desde 1 al 365/366 según corresponda.
    • epoch: devuelve el numero de segundos desde el 1970-01-01. Este valor puede ser negativo.También se puede utilizar para obtener el numero de segundos en un intervalo de tiempo. Ej. SELECT EXTRACT(EPOCH FROM INTERVAL'5 day 3 hours');
    • hour: devuelve la hora de la fecha, este valor esta entre 0 y 23.
    • microseconds: El tiempo en segundos, incluyendo la parte fraccionaria multiplicada por 1.000.000.
    • millennium: devuelve el valor del milenio del año. Ej. el año 1990 es el milenio 2 y el año 2001 es el milenio 3.
    • milliseconds: devuelve los segundos del campo tiempo multiplicado por 1.000.
    • minute: devuelve los minutos del campo, este valor esta definido entre 0 y 59.
    • month: Para valores timestamp, devuelve el numero del mes sin el año, los valores están definidos entre 0 y 12. También permite obtener intervalos de meses. Ej. SELECT EXTRACT (MONTH FROM INTERVAL '2 years 3 months');
    • quarter: Divide el año en cuatro y devuelve valores entre 1 y 4, según el intervalo en que se encuentre el día en el año.
    • second: devuelve la cantidad de segundos incluyendo la parte fraccionaria del campo.
    • timezone: La zona horaria en UTC, medida en segundos, los valores positivos corresponden a la zona horaria este de UTC y los valores negativos a la zona horaria oeste de UTC.
    • timezone_hour: La hora correspondiente de la zona horaria.
    • timezone_minute: Los minutos correspondientes a la zona horaria.
    • week: El número de la semana del año.
    • year: devuelve el año de la fecha, no hay año 0, así que hay años antes de Cristo y después de Cristo.
    "Gracias, por compartir tus conocimientos"