3

次のようなスペースとタグを含む文字列があります。

<note label="description">sp|P02671|FIBA_HUMAN Fibrinogen alpha chain OS=Homo sapiens GN=FGA PE=1 SV=2</note>

説明タグの後と「OS =」の前の部分のみをキャプチャしたいのですが、sscanf をカスタム表記で行うのが理にかなっているのか (ページの下部にある現在進行中の作業を参照)、それとも使用した方がよいのか疑問に思っていました。 OS を解析するための 2 番目の strstr。

前もって感謝します

- 追加情報 -

if ( (p_str = (char*) strstr(buffer,"\"description\">")) ) {
  sscanf(p_str+14,"%[^OS]",(file+teller)->description);
}

PS: %[^OS] は、'O' が最初に出現した時点で文字列を分割します。一連の文字を入力する方法を知りたいです (可能であれば)。

4

1 に答える 1

1

次のように、2回使用したいと思いstrstrます。

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

char *f (const char *s) {
#define START_SYM   "\"description\""
#define END_SYM     "OS="

    char *dst   = NULL;
    char *start = strstr(s, START_SYM);
    char *end   = strstr(s, END_SYM);

    if (start != NULL && end != NULL) {
        ptrdiff_t diff = end - start;

        assert(diff > 0);
        dst = malloc(diff + 1);

        if (dst != NULL) {
            memcpy(dst, start + sizeof START_SYM, diff);
            dst[diff] = '\0';
        }
    }

    return dst;
}
于 2013-02-25T17:17:49.773 に答える