Попытка подсчитать количество запятых в строке и сохранить в счетчике int - PullRequest
1 голос
/ 04 мая 2020

Я получаю сообщение об ошибке «Предупреждение: сравнение между указателем и целым числом». Я попытался использовать char * и все еще получил ту же ошибку. Я хочу посчитать количество запятых, которые появляются в строке, и поместить количество вхождений в счетчик.

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


int main(int argc, char *argv[]) {

    /*FILE *fp;
    fp = fopen("csvTest.csv","r");
    if(!fp){
        printf("File did not open");
    }*/


    //char buff[BUFFER_SIZE];
    char buff[100] = "1000,cap_sys_admin,cap_net_raw,cap_setpcap";    

    /*fgets(buff, 100, fp);
    printf("The string length is: %lu\n", strlen(buff));
    int sl = strlen(buff);*/

    int count = 0;
    int i;
    for(i=0;buff[i] != 0; i++){
        count += (buff[i] == ",");
    }
    printf("The number of commas: %d\n", count);




    char *tokptr = strtok(buff,",");
    char *csvArray[sl];

    i = 0;
    while(tokptr != NULL){
          csvArray[i++] = tokptr;
          tokptr = strtok(NULL, ",");
    }

    int j;
    for(j=0; j < i; j++){
        printf("%s\n", csvArray[j]);
    }

    return 0;
}

1 Ответ

2 голосов
/ 04 мая 2020

Например, в этом операторе

count += (buff[i] == ",");

вы сравниваете объект buff[i], имеющий тип char, со строковым литералом ",", который в выражении сравнения неявно преобразуется в введите const char *.

Вам необходимо сравнить символ с символом, используя символьный литерал ',' подобно

count += (buff[i] == ',');

Другой подход заключается в использовании стандартной функции C strchr.

for ( const char *p = buff; ( p = strchr( p, ',' ) ) != NULL; ++p )
{
    ++count;
}

Обратите внимание на наличие опечатки в состоянии l oop

for(i=0;i<buff[i] != 0; i++){

Вы должны написать

for(i=0; buff[i] != 0; i++){

Также кажется, что вместо этой декларации

char *csvArray[sl];

вы имеете в виду что-то вроде

char *csvArray[count + 1];
...