簡體   English   中英

在C中讀取CSV文件

[英]Read a CSV file in C

我必須在C控制台中讀取一個文件,該文件是CSV文件。 我的代碼如下:

printf("Ajouter un site internet \n");
        printf("------------------------------------------\n");
        FILE * curseur = fopen("listess.csv", "a");
        SITES * pSites = calloc(100000, sizeof(SITES));
        int i = 0;
        int iSites = 0;
        int champSites = 0;
        char temp[1000];
        if (curseur != NULL) {
            char c = fgetc(curseur);
            while (c != EOF) {
                printf("%s", (pSites + iSites)->url);
                if (c != '\n' && c != ';') {
                    temp[i] = c;
                    i++;
                }

                else if (c == ';') {
                    temp[i] = '\0';
                    if (champSites == 0) {
                        strcpy((pSites + iSites)->Commune, temp);
                        champSites++;
                        i = 0;
                    }
                    else if (champSites == 1) {
                        strcpy((pSites + iSites)->Insee, temp);
                        champSites++;
                        i = 0;
                    }
                    else if (champSites == 2) {
                        strcpy((pSites + iSites)->url, temp);
                        champSites++;
                        i = 0;
                    }
                    else if (champSites == 3) {
                        strcpy((pSites + iSites)->Population, temp);
                        champSites++;
                        i = 0;
                    }
                    else if (champSites == 4) {
                        strcpy((pSites + iSites)->https, temp);
                        champSites++;
                        i = 0;
                    }
                    else if (champSites == 5) {
                        strcpy((pSites + iSites)->Serveur, temp);
                        champSites++;
                        i = 0;
                    }
                    else if (champSites == 6) {
                        strcpy((pSites + iSites)->Version, temp);
                        champSites++;
                        i = 0;
                    }
                    else if (champSites == 7) {
                        strcpy((pSites + iSites)->Application, temp);
                        champSites++;
                        i = 0;
                    }

                    else if (champSites == 8) {
                        strcpy((pSites + iSites)->VersionApplication, temp);
                        champSites++;
                        i = 0;
                    }
                    else if (champSites == 9) {
                        strcpy((pSites + iSites)->Langage, temp);
                        champSites++;
                        i = 0;
                    }
                    else if (champSites == 10) {
                        strcpy((pSites + iSites)->VersionLangage, temp);
                        champSites++;
                        i = 0;
                    }
                    else if (champSites == 11) {
                        strcpy((pSites + iSites)->Latitude, temp);
                        champSites++;
                        i = 0;
                    }
                    else if (champSites == 12) {
                        strcpy((pSites + iSites)->Longitude, temp);
                        champSites++;
                        i = 0;
                    }
                }
                else {
                    iSites++;
                }
                c = fgetc(curseur);
            }
            system("pause");
            fclose(curseur);
        }

但是除了前兩行外,我在控制台中沒有任何結果。 該文件由我在.h文件中聲明的13列組成。

CSV的前5行:

Commune;Code Insee;url;Population;https;Serveur;Version du serveur;Application;Version de l'application;Langage;Version du langage;Latitude;Longitude
Argentat;19010;argentat.fr;3042;non;SiteW;2;Inconnue;Inconnue;php;5.3.29;45.100801186828598;1.934640270901890
Canenx-et-Réaut;40064;mairie-info.com;175;non;SiteW;2;Inconnue;Inconnue;php;5.3.29;43.999060134922502;-0.464769980981436
Chaussan;69051;chaussan.fr;972;non;SiteW;2;Inconnue;Inconnue;Inconnue;Inconnue;45.637283899086498;4.634069843807340
Étrez;1154;etrez.fr;803;non;SiteW;2;Inconnue;Inconnue;Inconnue;Inconnue;46.338283686023097;5.192873875680920
Gray ;70279;ville-gray.fr;6016;non;SiteW;2;Inconnue;Inconnue;php;5.2.10;47.432262030641297;5.610925314619960

您的代碼過於復雜。 扔掉它,並基於此創建新代碼:

#include <stdlib.h>
#include <stdio.h>
#include <string.h>

int main()
{
  // declare and initialize your pSites stuff here
  ....
  //

  if (curseur == NULL)
  {
    printf("Can't open file\n");
    return 1;
  }

  int linenumber = 1;
  char buffer[1000];

  while (fgets(buffer, sizeof buffer, curseur))
  {
    char *token = strtok(buffer, ";");
    printf("Line %d\n", linenumber++);

    int column = 0;
    while (token != NULL)
    {
      printf("%2d    %s\n", column, token);

      switch (column)
      {
        case 0:
          strcpy((pSites + iSites)->Commune, token);
          break;

        case 1:
          strcpy((pSites + iSites)->Insee, token);
          break;

        case 2:
         .... etc.
      }

      token = strtok(NULL, ";");
      column++;
    }

    iSites++;
  }

  fclose(curseur);
}

順便說一句:而不是寫作

(pSites + iSites)->Commune

您應該編寫更具可讀性的變體:

pSites[iSites]->Commune

這個:

                if (champSites == 0) {
                    strcpy((pSites + iSites)->Commune, temp);
                    champSites++;
                    i = 0;
                }
                else if (champSites == 0) {
                    strcpy((pSites + iSites)->Insee, temp);
                    champSites++;
                    i = 0;
                }

毫無意義,請注意,這兩個條件都是else if(champSites == 0) ,這顯然意味着大多數代碼已死(永遠不會執行)。

應該是if 0 ... else if 1 ... else if 2等等。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM