The UNIX and Linux Forums  


Go Back   El UNIX y Linux Foros > Arriba Foros > Programación de scripts de shell y
.
google unix.com



Programación de scripts de shell y Plantear preguntas sobre KSH, CSH, SH, BASH, PERL, PHP, SED, AWK y otros scripts de shell y lenguajes de script de shell aquí.

Más UNIX y Linux Foro Temas usted puede encontrar útiles
Hilo Hilo para principiantes Foro Respuestas Último mensaje
Agregar una columna a un texto basado en el nombre del archivo rlapate Programación de scripts de shell y 12 05-23-2009 10:22 PM
Filtrado de los registros de un archivo basado en un valor de una columna risk_sly UNIX for Dummies Preguntas y Respuestas 4 09-24-2008 03:22 AM
clasificación de archivos basado en dos o más columnas labrazil Programación de scripts de shell y 2 09-17-2008 12:19 AM
Recuperar la línea de un archivo basado en un valor específico en la columna efernandes UNIX for Dummies Preguntas y Respuestas 1 01-27-2007 11:04 AM
Ordenar un archivo basado en múltiples columnas (con posición de carácter) cucubird Programación de scripts de shell y 8 07-25-2006 01:47 AM

Reply
English Japanese Spanish French German Portuguese Italian Dutch Swedish Russian Norwegian Hungarian Hebrew Danish Bulgarian Greek Powered by Powered by Google
 
Linkback vínculo Herramientas de hilo Buscar en este Hilo Tasa de Hilo Modos de visualización
  #1 (Enlace permanente)  
Old 07-03-2009
tententen tententen is offline
Usuario Registrado
  
 

Fecha: diciembre 2008
Puestos: 17
csv clasificación sobre la base de la columna seleccionada

Hola a todos,

csv en mi lo más fácil es que este aspecto y, por supuesto, puede haber más columnas

EE.UU. al Reino Unido; abc-hq-JCL; multimedia
Reino Unido a NC; def-ny-jkl; estándar
DE DM; abc-ab-KLM; crítica
FD a YM; año-la-tym; estándar
ÍA del MC; año-la-ytm; multimedia
GT a KJ; def-ny-JRT; crítica

Quisiera grupo sobre la base de la 3 ª columna en primer lugar, a continuación, tipo 2 de ellos sobre la base de la columna por lo que verá como este

DE DM; abc-ab-KLM; crítica
GT a KJ; def-ny-JRT; crítica
EE.UU. al Reino Unido; abc-hq-JCL; multimedia
ÍA del MC; año-la-ytm; multimedia
Reino Unido a NC; def-ny-jkl; estándar
FD a YM; año-la-tym; estándar

también sería bueno que de alguna manera puedo hacer que se vea como este lo que le parezca más presentables: P,

CRÍTICO
DE DM; abc-ab-KLM; crítica
GT a KJ; def-ny-JRT; crítica

Multimedia
EE.UU. al Reino Unido; abc-hq-JCL; multimedia
ÍA del MC; año-la-ytm; multimedia

Norma
Reino Unido a NC; def-ny-jkl; estándar
FD a YM; año-la-tym; estándar
  #2 (Enlace permanente)  
Old 07-03-2009
vidyadhar85's Avatar
vidyadhar85 vidyadhar85 is offline Forum Staff  
Moderador (el tutor)
  
 

Fecha: junio 2008
Ubicación: INDIA
Mensajes: 1.415
hmmm uso tipo comando

Código:
sort -t";" -k3 -k2 filename

y para la segunda petición utilización awk ..

Código:
sort -t";" -k3 -k2 filename|awk -F\; '{A[$3]=A[$3]"\n"$0}END{for (i in A){print toupper(i)A[i]}}'

  #3 (Enlace permanente)  
Old 07-04-2009
kshji's Avatar
kshji kshji is offline
Usuario Registrado
  
 

Fecha: junio 2009
Ubicación: Finlandia
Puestos: 236
Uso de awk norma idea.

Código:
ff=file.txt

sort -t";" -k3 -k2 $ff | \
   awk -F";" -v keyfld=3 '
      # - next key value
      $keyfld != prevkey { 
                print toupper($keyfld) 
                }
      # - every line
                { 
                print $0
                prevkey=$keyfld
                }
   '

O el uso de ksh

Código:
prevkey=""
oifs="$IFS"
typeset -u key
sort -t";" -k3 -k2 $ff | while read line
do
        IFS=";"
        set -A flds -- $line    # to array, 1st index 0 
        IFS="$oifs"
        key=${flds[2]}
        [ "$prevkey" != "$key" ] && print "$key"
        print "$line"
        prevkey=$key
done

  #4 (Enlace permanente)  
Old 07-04-2009
scottn scottn is online now Forum Advisor  
Miembro VIP
  
 

Fecha: junio 2009
Ubicación: Zürich, CH
Puestos: 1.108
Porque usted ha dicho

Cita:
... puede haber más columnas
Una ligera modificación del código de vidyadhar85

Código:
sort -t";" -k3 -k2 filename|awk -F\; '{A[$NF]=A[$NF]"\n"$0}END{for (i in A) {print toupper(i)A[i]}}'

  #5 (Enlace permanente)  
Old 07-05-2009
summer_cherry summer_cherry is offline Forum Advisor  
Usuario Registrado
  
 

Fecha: junio 2007
Ubicación: Beijing China
Mensajes: 1.092
a continuación acerca de cómo perl:


Código:
my @arr=<DATA>;
print map {$_->[0]}
      sort {$a->[1]->[2] cmp $b->[1]->[2] or $a->[1]->[1] cmp $b->[1]->[1]}
      map {my @tmp=split(";",$_);[$_,\@tmp]}
      @arr;
__DATA__
US to UK;abc-hq-jcl;multimedia
UK to CN;def-ny-jkl;standard
DE to DM;abc-ab-klm;critical
FD to YM;la-yr-tym;standard
HY to MC;la-yr-ytm;multimedia
GT to KJ;def-ny-jrt;critical

Reply

Marcadores

Herramientas de hilo Buscar en este Hilo
Buscar en este Hilo:

Búsqueda avanzada
Modos de visualización Vota a este hilo
Vota a este hilo:

Normas de envío
puede que no nuevo puesto de hilos
puede que no enviar respuestas
puede que no enviar archivos adjuntos
puede que no editar sus puestos

Código BB es Encendido
Emoticones son Encendido
[IMG] código Encendido
Código HTML es Apagado
Trackbacks son Encendido
Pingbacks son Encendido
Refbacks son Encendido




Todas las horas son GMT -4. La hora es 10:34 AM.


Powered by: vBulletin, Copyright © 2000 - 2006, Jelsoft Enterprises Limited. Traducciones de idiomas Powered by .
vBCredits v1.4 Copyright © 2007 - 2008, PixelFX Estudios
El UNIX y Linux Foros Contenido Copyright © 1993-2009. Todos los derechos Reserved.Ad Gestión por RedTyger

Las direcciones URL de contenido vBSEO 3.2.0