2 00:00:00,000 --> 00:00:02,470 >> 1 głośnik: Napiszmy program, który pyta użytkownika o nazwach i 3 00:00:02,470 --> 00:00:03,990 domy z trzech uczniów. 4 00:00:03,990 --> 00:00:07,300 Ale zamiast po prostu wydrukować ich Nazwy i domy do ekranu, niech 5 00:00:07,300 --> 00:00:09,660 zamiast zapisać te informacje na dysku. 6 00:00:09,660 --> 00:00:14,530 Innymi słowy, stwórzmy, powiedzmy, CSV Plik, do oddzielonych przecinkami wartości, 7 00:00:14,530 --> 00:00:17,720 który jest po prostu plik tekstowy programy takie jak Excel lub numery 8 00:00:17,720 --> 00:00:21,690 można otworzyć, i skutecznie zapisać te Nazwy i domy na stałe tak, że 9 00:00:21,690 --> 00:00:23,220 możemy się z nimi później. 10 00:00:23,220 --> 00:00:25,960 >> Aby to zrobić, niech najpierw przyjrzeć jakiś kod boilerplate że mam 11 00:00:25,960 --> 00:00:27,650 Zaczęło się już. 12 00:00:27,650 --> 00:00:32,380 Zauważ najpierw, że wśród nagłówkami do góry jest obecnie standardem lib.h które 13 00:00:32,380 --> 00:00:36,710 zdarza się mieć jakieś funkcje związane do pliku I / O, wejście i wyjście plików. 14 00:00:36,710 --> 00:00:39,560 Zauważ, że ja również uznane stała zwany STUDENCI - 15 00:00:39,560 --> 00:00:42,380 we wszystkich czapkach - których wartość jest zakodowana w trzech. 16 00:00:42,380 --> 00:00:45,820 Zauważ teraz, że we wnętrzu moim głównym Program, jestem deklarując tablicę 17 00:00:45,820 --> 00:00:50,270 Rozmiar trzy stałej nazwie przy użyciu tego STUDENCI której każdy z członków ma 18 00:00:50,270 --> 00:00:51,650 wpisz studentów. 19 00:00:51,650 --> 00:00:56,150 >> Przypomnijmy teraz, że uczeń będziemy definiować jako posiadający nazwę i zarówno z domu 20 00:00:56,150 --> 00:01:00,410 które są łańcuchami, jak na to Deklaracja nakazuje, dot h. 21 00:01:00,410 --> 00:01:04,680 Teraz z powrotem w structs1.c, zauważył, że nie tu, że na pętli będzie 22 00:01:04,680 --> 00:01:06,750 iteracji od zera do trzech. 23 00:01:06,750 --> 00:01:10,020 To będzie skłonić mnie do ucznia Nazwa i dom studenta 24 00:01:10,020 --> 00:01:12,310 znowu i znowu i znowu. 25 00:01:12,310 --> 00:01:15,620 >> Następnie, w dolnej części tego programu zauważyć, że mam inny pętli 26 00:01:15,620 --> 00:01:19,970 że zamierza zwolnić studenta-ty jest Nazwa i dom studenta ith w 27 00:01:19,970 --> 00:01:21,570 Podobnie skonstruowana pętli. 28 00:01:21,570 --> 00:01:24,480 Aby upewnić się, możemy połączyć te pętle się tylko jeden, ale chciałem 29 00:01:24,480 --> 00:01:28,180 mają pewne odrębne segmenty kodu dla dobra dyskusji tutaj. 30 00:01:28,180 --> 00:01:31,920 >> Teraz między tymi, dla pętli, niech rzeczywiście inny, a ten jest 31 00:01:31,920 --> 00:01:35,210 Celem życia jest rzeczywiście zapisać wszystkie z tych nazw i domów, które są 32 00:01:35,210 --> 00:01:39,810 aktualnie w pamięci RAM na dysku w formie z oddzielonych przecinkami wartości. 33 00:01:39,810 --> 00:01:42,080 Aby to zrobić, będziemy korzystać trzy nowe funkcje - 34 00:01:42,080 --> 00:01:47,450 F otwarty, F printf i F w pobliżu, które otworzyć plik, wydrukować do pliku, a 35 00:01:47,450 --> 00:01:48,440 zamknięciu pliku. 36 00:01:48,440 --> 00:01:49,690 Możemy wykorzystywać je w następujący sposób. 37 00:01:49,690 --> 00:01:52,110 38 00:01:52,110 --> 00:01:58,240 >> Plik, wszystkie czapki, które jest trochę ciekawość w C, plik zostanie fopen 39 00:01:58,240 --> 00:02:03,020 cytatu, a teraz nazwa pliku, powiedzmy, students.CSV, ale mogłem 40 00:02:03,020 --> 00:02:08,150 Nazywamy to najbardziej wszystko, przecinek i teraz jestem będzie określić jeden w środku 41 00:02:08,150 --> 00:02:09,390 z podwójnym cudzysłowie. 42 00:02:09,390 --> 00:02:13,290 W, jak może już domyślacie, Oznacza to, że fopen należy otworzyć ten plik 43 00:02:13,290 --> 00:02:17,360 nazywa Students.CSV do pisania tak że możemy rzeczywiście mało 44 00:02:17,360 --> 00:02:19,370 Treści do niego. 45 00:02:19,370 --> 00:02:23,080 >> Niech obok sprawdzić, czy plik nie jest równa null. 46 00:02:23,080 --> 00:02:25,860 Bo jeśli tak jest, prawdopodobnie coś ma poszło nie tak w tym przypadku mamy 47 00:02:25,860 --> 00:02:28,340 Nie należy kontynuować, aby spróbować wszystko drukować na nim. 48 00:02:28,340 --> 00:02:33,400 Ale jeśli to nie jest pusty, wewnątrz nawiasy klamrowe Idę do iteracji 49 00:02:33,400 --> 00:02:38,030 od i jest równe 0 na do studentów, i mam zamiar 50 00:02:38,030 --> 00:02:40,180 i przyrost po każdej iteracji. 51 00:02:40,180 --> 00:02:45,750 I wewnątrz tej pętli, mam zamiar fprintf, tak aby drukowanie do pliku - 52 00:02:45,750 --> 00:02:47,940 konkretnie jeden Już otwarte - 53 00:02:47,940 --> 00:02:54,650 Ciąg, który wygląda jak ten% s,% s odwrotny ukośnik n blisko cytatu. 54 00:02:54,650 --> 00:02:58,790 >> I teraz chcę podłączyć do każdego z te zastępcze wartości rzeczywiste 55 00:02:58,790 --> 00:03:03,390 nazwy studenta i dom za pomocą operatora kropki. 56 00:03:03,390 --> 00:03:10,030 Uchwyt studentów i.name, studentów Uchwyt i.house zamknij nawias 57 00:03:10,030 --> 00:03:11,230 średnik. 58 00:03:11,230 --> 00:03:16,180 Teraz poniżej to dla pętli, po prostu jestem Zadzwonię fclose pliku w celu 59 00:03:16,180 --> 00:03:18,520 aby ostatecznie zamknąć plik. 60 00:03:18,520 --> 00:03:21,360 >> Teraz gdy uruchamiam ten program, nie powinien faktycznie cokolwiek zobaczyć na 61 00:03:21,360 --> 00:03:25,010 ekran, ale powinienem mieć po uruchomieniu program ten plik o nazwie 62 00:03:25,010 --> 00:03:29,130 Students.CSV w tym samym katalogu, w którym Uruchomić polecenie, które powinny 63 00:03:29,130 --> 00:03:32,480 zawierać oddzielone przecinkami lista wartości. 64 00:03:32,480 --> 00:03:34,790 Rzućmy okiem. 65 00:03:34,790 --> 00:03:41,690 >> Złóż elemencie 1. / Structs1 studenta Nazwa, powiedzmy David, 66 00:03:41,690 --> 00:03:43,140 będzie żył w Mather. 67 00:03:43,140 --> 00:03:46,890 Nazwisko studenta, powiedzmy, Lauren, ona mieszka w Leverett. 68 00:03:46,890 --> 00:03:50,800 Nazwisko studenta, powiedzmy, Rob, będzie żył w Kirkland. 69 00:03:50,800 --> 00:03:54,050 Teraz znowu, zgodnie z oczekiwaniami, nic się nie pojawia się nie stało, ale pozwól mi 70 00:03:54,050 --> 00:03:58,790 śmiało w wierszu polecenia i typu g edytuj students.CSV w nadziei, że 71 00:03:58,790 --> 00:04:00,850 że plik rzeczywiście istnieje. 72 00:04:00,850 --> 00:04:07,010 >> Gedit students.CSV ENTER, i rzeczywiście, Zauważ, że plik zawierający wyłącznie 73 00:04:07,010 --> 00:04:11,320 tekst, ale tekst oddzielone przecinkami dla każdego pola, w rzeczywistości nie istnieje. 74 00:04:11,320 --> 00:04:14,530 A jeśli używaliśmy, nie CS50 Urządzenie, ale bardziej zaznajomieni Mac lub 75 00:04:14,530 --> 00:04:18,080 PC, okazuje się, że mogliśmy rzeczywiście otwórz ten plik CSV z więcej 76 00:04:18,080 --> 00:04:20,400 zna program jak Excel lub liczb. 77 00:04:20,400 --> 00:04:22,906