1 00:00:07,060 --> 00:00:08,420 [Powered by Google Translate] Tommy: I den här videon kommer vi att lära om 2 00:00:08,420 --> 00:00:10,140 omdirigera och rör. 3 00:00:10,140 --> 00:00:12,780 Hittills har vi använt funktioner som printf till 4 00:00:12,780 --> 00:00:15,590 utdata till terminalen och funktioner som GetString 5 00:00:15,590 --> 00:00:17,520 att låta användaren att bidra till vår 6 00:00:17,520 --> 00:00:19,490 program med tangentbordet. 7 00:00:19,490 --> 00:00:21,880 Låt oss ta snabbt en titt på ett program som får en rad 8 00:00:21,880 --> 00:00:25,960 inmatning från användaren och matar sedan ut den. 9 00:00:25,960 --> 00:00:28,990 >> På rad 7, vi uppmanar användaren efter en sträng, och 10 00:00:28,990 --> 00:00:31,680 sedan på rad 8, vi skriver den ut igen. 11 00:00:31,680 --> 00:00:35,220 Låt oss kompilera och köra vårt program. 12 00:00:35,220 --> 00:00:35,900 Jättebra. 13 00:00:35,900 --> 00:00:37,620 Strängen vi som upprepades tillbaka 14 00:00:37,620 --> 00:00:39,170 till oss på terminalen. 15 00:00:39,170 --> 00:00:42,110 Detta skedde på grund av printf funktionen skrev till en 16 00:00:42,110 --> 00:00:46,220 ström kallas standard ut eller s-t-d-ut. 17 00:00:46,220 --> 00:00:49,230 När något skrivs till stdout, det som standard 18 00:00:49,230 --> 00:00:51,110 visas av terminalen. 19 00:00:51,110 --> 00:00:53,720 >> Så det är allt gott och väl, men vad händer om, istället för att bara 20 00:00:53,720 --> 00:00:57,700 visa strängen, ville vi spara den till en fil? 21 00:00:57,700 --> 00:01:00,470 Till exempel kan vi vill minnas exakt vad vi 22 00:01:00,470 --> 00:01:04,450 Programmet gjorde när vi gav det en viss ingång senare. 23 00:01:04,450 --> 00:01:07,270 Ett sätt skulle vara att göra det i vår C-program med hjälp av 24 00:01:07,270 --> 00:01:09,680 några speciella funktioner för att skriva till filer som vi kommer 25 00:01:09,680 --> 00:01:11,270 se i en annan video. 26 00:01:11,270 --> 00:01:13,260 Ännu enklare, men skulle vara att på något sätt 27 00:01:13,260 --> 00:01:16,090 omdirigera stdout till en fil. 28 00:01:16,090 --> 00:01:19,780 På så sätt, när printf skriver till stdout, innehållet kommer 29 00:01:19,780 --> 00:01:21,720 skrivas till en fil i stället 30 00:01:21,720 --> 00:01:23,410 visas av terminalen. 31 00:01:23,410 --> 00:01:26,690 Vi kan göra just detta genom att lägga till en större-än-tecken följt 32 00:01:26,690 --> 00:01:30,820 av ett filnamn, till kommandot vi använder för att köra vårt program. 33 00:01:30,820 --> 00:01:34,730 >> Så snarare än att bara köra. / Redirect kan vi 34 00:01:34,730 --> 00:01:38,880 kör. / redirect, följt av en större än-tecken, följt av 35 00:01:38,880 --> 00:01:41,530 filnamn, som file.txt. 36 00:01:41,530 --> 00:01:44,290 Låt oss se vad som händer. 37 00:01:44,290 --> 00:01:45,130 OK. 38 00:01:45,130 --> 00:01:48,470 Observera att denna tid ingenting visas på terminalen, 39 00:01:48,470 --> 00:01:50,290 men vi har inte ändrat innehållet i vår 40 00:01:50,290 --> 00:01:52,040 C-program alls. 41 00:01:52,040 --> 00:01:56,090 Låt oss nu undersöka innehållet i den här katalogen med ls. 42 00:01:56,090 --> 00:01:56,630 >> Okej. 43 00:01:56,630 --> 00:02:00,840 Vi har nu en ny fil i vår katalog som heter file.txt, 44 00:02:00,840 --> 00:02:03,640 vilket är filnamnet levererade vi när vi körde vår 45 00:02:03,640 --> 00:02:05,050 Redirect programmet. 46 00:02:05,050 --> 00:02:08,020 Vi öppnar upp file.txt. 47 00:02:08,020 --> 00:02:11,840 Och här kan vi se att stdout ur omdirigera var 48 00:02:11,840 --> 00:02:15,550 skrivs till filen som heter file.txt. 49 00:02:15,550 --> 00:02:18,470 Så låt oss köra föregående kommando igen, men levererar en 50 00:02:18,470 --> 00:02:20,075 olika in denna gång. 51 00:02:25,140 --> 00:02:25,900 Okej. 52 00:02:25,900 --> 00:02:28,205 Låt oss ta en titt på file.txt nu. 53 00:02:31,070 --> 00:02:34,580 >> Vi kan här se att filen har skrivits över, så vår 54 00:02:34,580 --> 00:02:37,120 ursprungliga ingången finns inte längre. 55 00:02:37,120 --> 00:02:40,280 Om vi ​​istället vill lägga till den här filen, sätta nya 56 00:02:40,280 --> 00:02:43,600 ingång under de befintliga innehållet i filen kan vi 57 00:02:43,600 --> 00:02:46,800 Använd två större-än-tecken istället för bara en. 58 00:02:46,800 --> 00:02:48,050 Låt oss prova det. 59 00:02:52,160 --> 00:02:57,910 Nu, om vi öppnar file.txt igen, kan vi se både vår 60 00:02:57,910 --> 00:02:59,580 ingångsledningar. 61 00:02:59,580 --> 00:03:02,180 I vissa fall kan vi vill kasta något 62 00:03:02,180 --> 00:03:03,850 utgång vårt program. 63 00:03:03,850 --> 00:03:06,450 I stället för att skriva utdata till en fil och sedan ta bort 64 00:03:06,450 --> 00:03:09,310 filen när vi är klara med det, kan vi skriva en särskild 65 00:03:09,310 --> 00:03:12,360 fil som heter / dev / null. 66 00:03:12,360 --> 00:03:15,160 När allt är skrivet till / dev/null-- 67 00:03:15,160 --> 00:03:16,960 eller bara devnull för kort - 68 00:03:16,960 --> 00:03:18,950 den automatiskt kasseras. 69 00:03:18,950 --> 00:03:23,290 Så tänk på devnull som ett svart hål för dina data. 70 00:03:23,290 --> 00:03:26,070 >> Så nu har vi sett hur större än skylten kan omdirigera 71 00:03:26,070 --> 00:03:29,610 stdout, låt oss se hur vi kan omdirigera standard - 72 00:03:29,610 --> 00:03:31,250 eller s-t-d-in - 73 00:03:31,250 --> 00:03:33,550 den analog standard ut. 74 00:03:33,550 --> 00:03:36,010 Medan funktioner som printf skriva till kallas strömmen 75 00:03:36,010 --> 00:03:40,500 stdout, GetString och liknande funktioner läses från strömmen 76 00:03:40,500 --> 00:03:43,770 kallas stdin, som som standard är strömmen av 77 00:03:43,770 --> 00:03:46,290 tecken skrivs på tangentbordet. 78 00:03:46,290 --> 00:03:50,010 Vi kan omdirigera stdin med mindre än-tecken följt 79 00:03:50,010 --> 00:03:51,370 av ett filnamn. 80 00:03:51,370 --> 00:03:54,000 Nu, i stället för att användaren för inmatning på 81 00:03:54,000 --> 00:03:57,870 terminalen kommer ett program att öppna filen vi specificerade och använder 82 00:03:57,870 --> 00:03:59,790 dess linjer som indata. 83 00:03:59,790 --> 00:04:02,620 >> Låt oss se vad som händer. 84 00:04:02,620 --> 00:04:03,280 Jättebra. 85 00:04:03,280 --> 00:04:07,590 Den första raden i file.txt har skrivits till terminalen 86 00:04:07,590 --> 00:04:10,160 eftersom vi kallar GetString gång. 87 00:04:10,160 --> 00:04:13,170 Om vi ​​hade en annan uppmaning till GetString i vårt program, det 88 00:04:13,170 --> 00:04:16,149 nästa rad av fil.txt skulle ha använts som 89 00:04:16,149 --> 00:04:17,990 ingång till det samtalet. 90 00:04:17,990 --> 00:04:21,050 Återigen har vi ändrat inte vår C-program alls. 91 00:04:21,050 --> 00:04:23,620 Vi bara ändra hur vi kör den. 92 00:04:23,620 --> 00:04:27,080 Och även komma ihåg att vi inte har omdirigerats stdout den här gången, 93 00:04:27,080 --> 00:04:28,970 så att utsignalen från systemet fortfarande var 94 00:04:28,970 --> 00:04:31,040 visas på terminalen. 95 00:04:31,040 --> 00:04:33,500 Vi kan naturligtvis omdirigera både stdin 96 00:04:33,500 --> 00:04:37,320 och stdout så här. 97 00:04:37,320 --> 00:04:43,550 Nu innehåller file2.txt första raden fil.txt. 98 00:04:43,550 --> 00:04:46,140 >> Så med hjälp av dessa operatörer har vi kunnat läsa och 99 00:04:46,140 --> 00:04:48,130 skriva från textfiler. 100 00:04:48,130 --> 00:04:51,890 Nu ska vi se hur vi kan använda utdata från ett program som 101 00:04:51,890 --> 00:04:54,710 ingången till ett annat program. 102 00:04:54,710 --> 00:04:56,650 Så här är en annan enkel C-program som jag 103 00:04:56,650 --> 00:05:00,190 har här kallat hej.c. 104 00:05:00,190 --> 00:05:02,617 Som ni kan se, matar detta helt enkelt "Hej 105 00:05:02,617 --> 00:05:04,430 där! "för användaren. 106 00:05:04,430 --> 00:05:08,890 Om jag vill omdirigera använda som indata utgången av Hello - 107 00:05:08,890 --> 00:05:10,190 annat program - 108 00:05:10,190 --> 00:05:13,920 Jag kunde först omdirigera stdout av hej till en fil som heter 109 00:05:13,920 --> 00:05:18,960 input.txt sedan omdirigera stdin om omdirigering till samma 110 00:05:18,960 --> 00:05:21,190 fil - input.txt. 111 00:05:21,190 --> 00:05:26,730 Så jag kan göra. / Hej> input.txt. 112 00:05:26,730 --> 00:05:28,810 Tryck på Enter för att utföra detta. 113 00:05:28,810 --> 00:05:31,910 Följt av. / Redirect < 114 00:05:31,910 --> 00:05:35,270 input.txt och köra det. 115 00:05:35,270 --> 00:05:38,290 Så vi kan förkorta det lite med ett semikolon, som tillåter 116 00:05:38,290 --> 00:05:41,360 oss att köra två eller flera kommandon på samma linje. 117 00:05:41,360 --> 00:05:47,920 Så jag kan säga,. / Hej> input.txt, semikolon, 118 00:05:47,920 --> 00:05:50,580 . / Redirect 00:05:56,740 >> Så här fungerar, men det känns ändå ganska klumpiga. 120 00:05:56,740 --> 00:05:59,530 Jag menar, vi behöver verkligen den här filen mellanhand text som är 121 00:05:59,530 --> 00:06:02,520 inte längre nödvändigt efter omdirigera körningar? 122 00:06:02,520 --> 00:06:05,780 Lyckligtvis kan vi undvika denna extra textfil med vad 123 00:06:05,780 --> 00:06:07,220 kallas ett rör. 124 00:06:07,220 --> 00:06:13,740 Om jag säger, / hej |.. / Redirect, då stdout av 125 00:06:13,740 --> 00:06:15,310 programmet på vänster - 126 00:06:15,310 --> 00:06:16,740 i detta fall, hej - 127 00:06:16,740 --> 00:06:18,970 kommer att användas som standard ingång för 128 00:06:18,970 --> 00:06:20,370 programmet till höger. 129 00:06:20,370 --> 00:06:24,850 I det här fallet, omdirigera. Så låt oss köra. 130 00:06:24,850 --> 00:06:25,930 >> Där kör vi. 131 00:06:25,930 --> 00:06:30,080 Vi kan se att utsignalen från hello användes som indata 132 00:06:30,080 --> 00:06:31,520 för omdirigering. 133 00:06:31,520 --> 00:06:34,890 Genom stringing kommandon tillsammans med rör, bildar vi vad 134 00:06:34,890 --> 00:06:38,120 kallas en rörledning, eftersom vår produktion är i huvudsak rör 135 00:06:38,120 --> 00:06:40,590 genom en sekvens av kommandon. 136 00:06:40,590 --> 00:06:43,570 Med hjälp av rör, kan vi göra en del coola saker utan att behöva 137 00:06:43,570 --> 00:06:45,870 skriva någon kod alls. 138 00:06:45,870 --> 00:06:48,760 Till exempel, låt oss säga att vi vill veta hur många filer 139 00:06:48,760 --> 00:06:50,630 insidan av denna katalog. 140 00:06:50,630 --> 00:06:55,200 Med hjälp av ett rör, kan vi kombinera ls-kommandot med wc - 141 00:06:55,200 --> 00:06:56,460 eller wordcount - 142 00:06:56,460 --> 00:06:57,850 kommando. 143 00:06:57,850 --> 00:07:02,230 Ls kommer mata varje fil i katalogen till stdout och 144 00:07:02,230 --> 00:07:08,040 wc berättar hur många rader gavs till den via stdin. 145 00:07:08,040 --> 00:07:12,440 Så om vi säger ls | wc-l - 146 00:07:12,440 --> 00:07:16,800 levererar-l flaggan till wc för att berätta det att räkna rader - 147 00:07:16,800 --> 00:07:19,260 Vi kan se exakt hur många filer 148 00:07:19,260 --> 00:07:21,940 i den aktuella katalogen. 149 00:07:21,940 --> 00:07:24,570 >> Så låt oss ta en titt på ett exempel. 150 00:07:24,570 --> 00:07:27,740 Jag har här en fil som heter students.txt, 151 00:07:27,740 --> 00:07:29,600 med en lista med namn. 152 00:07:29,600 --> 00:07:32,730 Men dessa namn är inte i vilken ordning allt, och det ser 153 00:07:32,730 --> 00:07:34,850 Liksom några namn upprepas. 154 00:07:34,850 --> 00:07:38,510 Vad vi vill ha är en lista med unika namn i alfabetisk 155 00:07:38,510 --> 00:07:42,550 ordning, sparas i en fil som heter final.txt. 156 00:07:42,550 --> 00:07:45,210 Vi kunde naturligtvis skriva en C-program för att göra detta för oss. 157 00:07:45,210 --> 00:07:46,560 Men det kommer att bli onödigt 158 00:07:46,560 --> 00:07:48,560 komplex ganska snabbt. 159 00:07:48,560 --> 00:07:51,740 Låt oss istället använda rör och några inbyggd-verktyg för att lösa 160 00:07:51,740 --> 00:07:53,300 detta problem. 161 00:07:53,300 --> 00:07:57,760 >> Det första vi behöver göra är att läsa filen students.txt. 162 00:07:57,760 --> 00:08:00,530 Kommandot cat kommer att göra just det. 163 00:08:00,530 --> 00:08:03,230 Den kommer att läsa i den angivna filen och skriva 164 00:08:03,230 --> 00:08:05,750 dess innehåll till stdout. 165 00:08:05,750 --> 00:08:07,570 Efter att vi har läst textfilen, vi 166 00:08:07,570 --> 00:08:09,490 vill sortera namnen. 167 00:08:09,490 --> 00:08:12,510 Kommandot Sortera kan hantera detta för oss. 168 00:08:12,510 --> 00:08:16,830 Sortera matar ut linan matas via stdin till stdout 169 00:08:16,830 --> 00:08:19,310 i sorterad ordning. 170 00:08:19,310 --> 00:08:23,450 För att leverera innehållet i students.txt till 171 00:08:23,450 --> 00:08:29,600 Sortera: s standard in, kan vi använda ett rör för att kombinera katt och sortera. 172 00:08:29,600 --> 00:08:34,440 Så jag kan köra cat students.txt | sortera och 173 00:08:34,440 --> 00:08:35,640 tryck på Enter. 174 00:08:35,640 --> 00:08:39,309 Och nu ser vi innehåll students.txt i 175 00:08:39,309 --> 00:08:40,909 alfabetisk ordning. 176 00:08:40,909 --> 00:08:42,860 >> Så låt oss lägga till ytterligare kommando - 177 00:08:42,860 --> 00:08:44,730 Uniq, eller unik - 178 00:08:44,730 --> 00:08:46,230 till vår pipeline. 179 00:08:46,230 --> 00:08:49,810 Som du kan gissa, uniq, vid leverans en sorterad sekvens av 180 00:08:49,810 --> 00:08:53,650 linjer via stdin, matar ut de unika linjer. 181 00:08:53,650 --> 00:08:56,910 Så nu har vi katt students.txt 182 00:08:56,910 --> 00:09:00,040 | Sortera | uniq. 183 00:09:00,040 --> 00:09:03,330 Slutligen kan vi spara resultatet av rörledningen till en 184 00:09:03,330 --> 00:09:09,090 filen via katt students.txt | Sortera | uniq 185 00:09:09,090 --> 00:09:12,440 > Final.txt. 186 00:09:12,440 --> 00:09:16,260 Så, om vi öppnar final.txt har vi exakt vad vi var 187 00:09:16,260 --> 00:09:17,270 letar efter: 188 00:09:17,270 --> 00:09:20,180 en lista med unika namn i alfabetisk ordning, 189 00:09:20,180 --> 00:09:22,150 sparas i en textfil. 190 00:09:22,150 --> 00:09:26,020 Förresten, vi också kunde ha sagt Sortera < 191 00:09:26,020 --> 00:09:32,290 students.txt | Uniq> final.txt att göra exakt 192 00:09:32,290 --> 00:09:35,400 samma sak med hjälp var och en av de operatörer som vi har sett i 193 00:09:35,400 --> 00:09:36,580 denna video. 194 00:09:36,580 --> 00:09:39,540 >> Mitt namn är Tommy, och detta är CS50.