The UNIX and Linux Forums  


Go Back   UNIX och Linux Forum > Upp Forum > Shell-programmering och Skript
.
google unix.com



Shell-programmering och Skript Post frågor om ksh, CSH, SH, bash, PERL, PHP, sed, awk och andra skalskript och skal skriptspråk här.

Mer UNIX och Linux Forum Ämnen Du kan hitta Helpful
Tråd Thread Starter Forum Svar Senaste Inlägg
Ändra en kolumn i avgränsad fil kolumnen till fast bredd kolumn manneni Prakash Shell-programmering och Skript 5 06-22-2009 06:27
Byta kolumnen med kolumnen i en annan fil manneni Prakash UNIX for Dummies Frågor & Svar 1 06-25-2008 12:20
hur man läser kolumnen och skriv ut värden under kolumnen gemini106 Shell-programmering och Skript 6 03-28-2008 07:05
Så kontrollerar du Null värden i en fil kolumn efter kolumn om kolumnerna är inte NULLs Mandab Shell-programmering och Skript 7 03-15-2008 09:57
Ersätt 10:e kolonnen med en ny kolumn --- Terriblly bråttom ahmedwaseem2000 Shell-programmering och Skript 2 09-06-2005 02:10

Closed Thread
English Japanese Spanish French German Portuguese Italian Dutch Swedish Russian Norwegian Hungarian Hebrew Danish Bulgarian Greek Powered by Powered by Google
 
LinkBack Thread Tools Sök i denna tråd Rate Thread Visningslägen
  #1 (permalänk)  
Old 10-10-2008
Mish_99 Mish_99 is offline
Registered User
  
 

Join Date: Aug 2008
Inlägg: 10
kolumn hantering i awk

Bäste Scripting experter,

Jag har ett problem som jag inte kan få mitt huvud runt och undrade om någon kan hjälpa mig. Jag har två filer "fil1" och "fil2" och jag vill byta kolumn från en fil 1 med en kolumn med fil2. (Där filen två har många kolumner). Se exempel .. ive försökt att använda klipp och klistra, men fick myslef i en enda röra ...

fil1 fil2
1 9 66 8 A
2 8 3 9 B
3 66 4 25 C
4 66 2 6 D
7 4 3 3 E
5 4 5 45 F

Effekt: --
1 66 8 A
2 3 9 B
3 4 25 C
4 2 6 D
7 3 3 E
5 5 45 F

Finns det ett enkelt sätt jag kan göra detta i awk? helst skulle jag vilja ha en stomme som jag kunde åberopa att använda systemet kommando i en perl skript.

Tack


Mish
  #2 (permalänk)  
Old 10-10-2008
zaxxon's Avatar
zaxxon zaxxon is offline Forum Staff  
Moderator
  
 

Join Date: Sep 2007
Ort: Tyskland
Inlägg: 2.289
Ledsen, men jag kan inte urskilja, varav en del från fil1 och som från fil2. Kan du lägga upp dem på separata rader och använda dessa code tags please ^ ^
Också det luktar redan som "join" skulle vara ett bra val för verktyg att använda för det.
  #3 (permalänk)  
Old 10-10-2008
Mish_99 Mish_99 is offline
Registered User
  
 

Join Date: Aug 2008
Inlägg: 10
Hej, Osrry för att hoppas att detta hjälper till att klargöra frågor

Kod:
File 1
1
2
3
4
5
6
Kod:
File 2
 9    66 8  a
 8    3  9  b
 66   4  25 c
 66   2  6  d 
 4    3  3  e
 4    5  45 f
Kod:
output
  1    66 8  a
  2    3  9  b
  3    4  25 c
  4    2  6  d 
  5    3  3  e
  6    5  45 f
hjärtliga hälsningar


Mish
  #4 (permalänk)  
Old 10-10-2008
danmero danmero is offline Forum Advisor  
  
 

Join Date: Nov 2007
Ort: 45.48-73.63
Inlägg: 1.434
Det är ett försprång:
Kod:
awk 'NR==FNR{_[NR]=$0;next;}{$1=_[FNR];print}' file1 file2
  #5 (permalänk)  
Old 10-10-2008
radoulov's Avatar
radoulov radoulov is online now Forum Staff  
missbrukare
  
 

Join Date: Jan 2007
Ort: Варна, България / Milano, Italia
Inlägg: 2.910
Jag vill använda Perl direkt:

Kod:
$ head file*
==> file1 <==
1
2
3
4
5
6

==> file2 <==
 9    66 8  a
 8    3  9  b
 66   4  25 c
 66   2  6  d 
 4    3  3  e
 4    5  45 f
$ perl -e'
  open F1,"<file1"or die$!;open F2,"<file2"or die$!;
  s/([^\s]+)\s*/<F1>/eand s/\n/\t/and print while<F2>;
  close F1;close F2'         
 1      66 8  a
 2      3  9  b
 3      4  25 c
 4      2  6  d 
 5      3  3  e
 6      5  45 f

Senast redigerad av radoulov; 10-10-2008 at 09:43.. Orsak: refactored (fortfarande ganska nytt för Perl ...)
Closed Thread

Komihåglista

Thread Tools Sök i denna tråd
Sök i denna tråd:

Avancerad sökning
Visningslägen Betygsätt denna tråd
Betygsätt denna tråd:

Utstationering Regler
Du får inte efter nya trådar
Du får inte efter svar
Du får inte skicka bilagor
Du får inte redigera dina inlägg

BB-kod är
Smilies är
[IMG] kod
HTML-koden är Av
Trackback är
Pingbacks är
Refbacks är




Alla tider är GMT -4. Klockan är nu 04:06.


Powered by: vBulletin, Copyright © 2000 - 2006, Jelsoft Enterprises Limited. Översättningar Powered by .
vBCredits v1.4 Copyright © 2007 - 2008, PixelFX Studios
UNIX och Linux Forum Innehållet upphovsrättsskyddat © 1993-2009. All Rights Reserved.Ad förvaltning RedTyger

Content Relevant webbadresser från vBSEO 3.2.0