, awk er en glimrende unix scripting sprog til forarbejdning af tekstfiler.den udgave, er medtaget i de fleste linux distros er nationale samlingsregering awk eller glor for kort.jeg kan lide det for at trække data fra bestilte datasæt, såsom tekst lister og csv eksport fra dem.awk ser hver linje i en fil, som en særskilt post, og hvert enkelt punkt i en linje som et særskilt område, hvilket gør det muligt at skære og servere dine filer i alle former for fleksible metoder.den klassiske måde at illustrere dette med, /etc /passwd,; dette eksempel fingeraftryk hele indholdet:,, $awk (print $0} /etc /passwd årsag: x: 0:0: årsag: /root /bin /bash dæmon: x: 1: 1: 1 /bar /sbin dæmon.: /bin /sh bin: x: 2:2: bin: /bin: /bin /sh sys: x: 3:3: sys: /dev: /bin /sh, trykte, uden muligheder betyder "trykke hele linje", og $0, "hele", således at - 0, giver samme resultat.nu, du vil vel bare en liste af brugernavne og uids:, /etc /passwd, er perfekt for parsing med awk, fordi dens datafelter er afgrænset med koloner.så alt du gør, er at regne fra venstre fra og med 1. nummer inden du, og så få brugernavne og uids sådan her:,, $awk - f ":" "(print $1" "$3} /etc /passwd root 0 dæmon 1 bin 2. 3,,, - f, definerer deres feltseparator, og", ", tilføjer en plads.hvad, hvis du vil have uids anført først?let peasey, bare flytte variablerne rundt sådan her:,, $awk - f ":" "(print $3" "$1} /etc /passwd, lad os se på et eksempel. for at bruge awk til at migrere, en stor stak af finansielle data i gnucash.,, der importerer data i gnucash,, gnucash er en af kronjuvelerne af foss, en fantastisk og magtfulde regnskabs - program, der kører på linux, mac, og vinduer.du kan qif og import af filer, men der er kun delvis støtte til csv import.hvilket er en skam, fordi csv (comma separated values) giver en god generel udformning af bevægelige finansielle data fra et program til et andet, og mange finansielle ansøgninger støtte csv import og eksport, lad os sige, du har en kæmpe regneark, der indeholder år af finansielle data, og du beslutter, at det er tid til at putte det i en korrekt regnskabsføring program.eller vil du flytte fra forskellige regnskabs - program i gnucash, og det kan ikke støtte qif eller af, men det støtter csv export.du kan skrive alle data, eller du kan sætte dit es linux scripting kvalifikationer til at arbejde.arbejdsgangen først at skabe en god ren csv - fil, omdanne det til qif, og så importere de qif i gnucash.gnucash er meget kræsen med, der har en helt ren qif fil med fejl, så må vi sørge for, at det, for at sørge for, at du arbejder fra en kopi af din kilde fil.ikke spolere deres oprindelige!,, jeg holder dette eksempel enkle og kun anvende følgende qif områder:,,, d - dag, p - modtager, m - notat, t - beløb, n - nummer eller en note i check nummer område, l - kategori, der svarer til gnucash regnskaber,) - record slutter,,, vi skal også angive den kontotype i qif fil header, som disse eksempler:,,.type: bank!type: kontanter!type: ccard!type: invst,, qif specifikation støtter mange flere ting, og du kan se alle detaljer.hvis denne side nogensinde forsvinder bare gøre en søgen efter "qif spec" som det er klart dokumenteret.,, regneark er fab for masse ændringer, som til dato og nummer formater, så tag et kig på din csv i et regneark, før de prøver at konvertere det til qif.sikre, at deres tilbagetrækning er et minus, som -33.72, og brug ikke dollartegn.indskud kan have et plus, hvis du foretrækker, men det er ikke påkrævet.alle dine tilbagekøb og indskud skal være i en enkelt kolonne.det er, hvad min endelige barberet csv export ligner: 11 /03 /2008 kopi junction kopi af byggeforskrifter - 33.72 8732 forsyninger 11 /03 /2008 home depot murske - 17.05 8734 værktøjer 11 /03 /2008 dewalt service center oplader til bore -75.85 8735 værktøjer 11 /04 /2008 - bygningen levering margen murske -13.23 8736 værktøjer 11 /05 /2008 jane smith fakturaᛓ 8500.00 dep indkomst: kontrakter, hvis der overhovedet er en enkelt fejl overalt i qif fil gnucash import vil mislykkes.en fejl, jeg har, er flere minus tegn, som --33.72, ekstra decimaler, og forkert dato formatering.awk ligeglad, men gnucash.okay så, lad os omdanne vores venlige csv - i en qif fil:,, $(echo '!type: bank ". kat exportfile.csv