C語言字串中根據特定字元(串)分割
C語言字串操作函式有很多,這裡舉出需要用到的,其他請自行查詢。
1、len = strlen(p) ;//取字串長度
原型:size_t strlen(const char *s); 功能:統計字串string中字元的個數,字串的長度在 size_t 返回值中。
注意:strlen函式的功能是計算字串的實際長度,不包括'\0'在內。另外,strlen函式也可以直接測試字串常量的長度,如:strlen("HelloWorld")。
2、p1 = strchr(p, c);// 在字串中查詢指定字元
原型:char *strchr(const char *s, int c);
查詢字 串string中首次出現的位置, NULL結束符也包含在查詢中. 返回一個指標, 指向字元c在字串string中首次出現的位置, 如果沒有找到, 則返回NULL. p1 = strrchr(p, c);// 在字串中反向查詢
原型:char *strrchr(const char *s, int c);
查詢字元c在字串string中最後一次出現的位置, 也就是對string進行反序搜尋, 包含NULL結束符.
3、p2 = strstr(p, p1) ;// 查詢字串
原型:char *strstr(const char *haystack, const char *needle); 在字串haystack中查詢needle子串. 返回子串needle在haystack中首次出現位置的指標. 如果沒有找到子串needle, 則返回NULL. 如果子串needle為空串, 函式返回haystack.
4、strncpy(p, p1, n);// 複製指定長度字串
原型:char *strncpy(char *dest, const char *src, size_t n);
另外一個:char *strcpy(char *dest, const char *src);
strncpy:將字串src中前n個字元拷貝到字串dest中。
strcpy:將字串src中字元拷貝到字串dest中。
那麼,在一個母串中查詢關鍵字元(串),然後根據這個字元(串)將母串分割成若干個子字串,則程式碼可以這樣寫:
#include <stdio.h> #include <string.h> #include <stdlib.h> int main(int agrc, const char *argv) { char *p = "177:aaaa:001122....;178:bbbb:001122....;179:cccc:001122...."; int i = 0, j = 0; char tmp[32][32] = {0}; char *p1 = (char *)malloc(1024); while((p1 = strchr(p, ';')) != NULL) { strncpy(tmp[i], p, strlen(p) - strlen(p1)); p = p1 + 1; i ++; } strncpy(tmp[i], p, strlen(p)); for(j = 0; j <= i; j++) printf("tmp[%d] = %s\n", j, tmp[j]); return 0; }