18

Cでは、char配列を区切り文字で区切るにはどうすればよいですか?それとも、文字列を操作する方が良いですか?いくつかの優れたC文字操作関数は何ですか?

4

7 に答える 7

22
#include<string.h>
#include<stdio.h>
int main()
{
    char input[16] = "abc,d";
    char *p;
    p = strtok(input, ",");

    if(p)
    {
    printf("%s\n", p);
    }
    p = strtok(NULL, ",");

    if(p)
           printf("%s\n", p);
    return 0;
}

このプログラムを見ることができます。最初にstrtok(input、 "、")。inputを使用する必要があります。次に、strtok(NULL、 "、")を使用します。戻り値がtrueの場合、他のグループを出力できます。

于 2012-04-27T13:58:27.773 に答える
12

strtok()を見てくださいstrtok()はリエントラント関数ではありません。

strtok_r()は、strtok()の再入可能なバージョンです。マニュアルのサンプルプログラムは次のとおりです。

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

   int main(int argc, char *argv[])
   {
       char *str1, *str2, *token, *subtoken;
       char *saveptr1, *saveptr2;
       int j;

       if (argc != 4) {
           fprintf(stderr, "Usage: %s string delim subdelim\n",argv[0]);
           exit(EXIT_FAILURE);
       }

       for (j = 1, str1 = argv[1]; ; j++, str1 = NULL) {
           token = strtok_r(str1, argv[2], &saveptr1);
           if (token == NULL)
               break;
           printf("%d: %s\n", j, token);

           for (str2 = token; ; str2 = NULL) {
               subtoken = strtok_r(str2, argv[3], &saveptr2);
               if (subtoken == NULL)
                   break;
               printf(" --> %s\n", subtoken);
           }
       }

       exit(EXIT_SUCCESS);
   }

別の区切り文字に基づいて前のトークンから取得されたサブトークンを操作するサンプル実行:

$ ./a.out hello:word:bye=abc:def:ghi = :

1: hello:word:bye
 --> hello
 --> word
 --> bye
2: abc:def:ghi
 --> abc
 --> def
 --> ghi
于 2012-04-27T10:51:37.507 に答える
4

1つのオプションはstrtokです

例:

char name[20];
//pretend name is set to the value "My name"

2つの単語の間のスペースで分割したい

split=strtok(name," ");

while(split != NULL)
{
    word=split;
    split=strtok(NULL," ");
}
于 2012-04-27T10:54:10.297 に答える
3

区切り文字をNULL文字に置き換えるだけで、新しく作成されたNULL文字の後のアドレスを新しいchar*ポインターに格納できます。

char* input = "asdf|qwer"
char* parts[10];
int partcount = 0;

parts[partcount++] = input;

char* ptr = input;
while(*ptr) { //check if the string is over
    if(*ptr == '|') {
        *ptr = 0;
        parts[partcount++] = ptr + 1;
    }
    ptr++;
}

もちろん、入力文字列に9つを超える区切り文字が含まれている場合、このコードは機能しないことに注意してください。

于 2012-04-27T10:58:35.553 に答える
3

私はこれを思いついた。これは私にとって最もうまくいくようだ。それは数の文字列を変換し、それを整数の配列に分割する:

void splitInput(int arr[], int sizeArr, char num[])
{
    for(int i = 0; i < sizeArr; i++)
        // We are subtracting 48 because the numbers in ASCII starts at 48.
        arr[i] = (int)num[i] - 48;
}
于 2015-09-05T15:41:19.853 に答える
1

これが私のやり方です。

void SplitBufferToArray(char *buffer, char * delim, char ** Output) {

    int partcount = 0;
    Output[partcount++] = buffer;

    char* ptr = buffer;
    while (ptr != 0) { //check if the string is over
        ptr = strstr(ptr, delim);
        if (ptr != NULL) {
            *ptr = 0;
            Output[partcount++] = ptr + strlen(delim);
            ptr = ptr + strlen(delim);
        }

    }
    Output[partcount++] = NULL;
}
于 2018-10-29T17:23:11.347 に答える
0

さらに、sscanfいくつかの非常に単純なシナリオに使用できます。たとえば、文字列に含まれる部分の数と文字列の構成が正確にわかっている場合などです。引数をその場で解析することもできます。関数は変換エラーを報告しないため、ユーザー入力には使用しないでください。

例:

char text[] = "1:22:300:4444:-5";
int i1, i2, i3, i4, i5;
sscanf(text, "%d:%d:%d:%d:%d", &i1, &i2, &i3, &i4, &i5);
printf("%d, %d, %d, %d, %d", i1, i2, i3, i4, i5);

出力:

1、22、300、4444、-5

他の回答で述べられているように、より高度なものについては、strtok()strtok_r()が最良のオプションです。

于 2019-04-10T18:09:30.753 に答える