通過學習和使用個人認為,在字符串格式不是很復雜,但是也并不簡單的時候用這個函數比較合適,這個尺度就要靠自己把握了,字符串不是很復雜,但自己寫個處理的函數比較麻煩,效率也不高,就用這個函數,如果字符串很復雜,那就用正則表達式吧。
不多說了,看看下面這些介紹和列子吧!
函數原型:
Int sscanf( string str, string fmt, mixed var1, mixed var2 ... );
int scanf( const char *format [,argument]... );
sscanf與scanf類似,都是用于輸入的,只是后者以屏幕(stdin)為輸入源,前者以固定字符串為輸入源。
其中的format可以是一個或多個 {%[*] [width] [{h | l | I64 | L}]type | ' ' | '\t' | '\n' | 非%符號}
%[a-z] 表示匹配a到z中任意字符,貪婪性(盡可能多的匹配)
%[aB'] 匹配a、B、'中一員,貪婪性
%[^a] 匹配非a的任意字符,貪婪性
1. 常見用法。
char buf[512] = {0};
sscanf("123456 ", "%s", buf);
printf("%s\n", buf);
結果為:123456
sscanf("123456 ", "%4s", buf);
printf("%s\n", buf);
結果為:1234
sscanf("123456 abcdedf", "%[^ ]", buf);
printf("%s\n", buf);
結果為:123456
4. 取僅包含指定字符集的字符串。如在下例中,取僅包含1到9和小寫字母的字符串。
sscanf("123456abcdedfBCDEF", "%[1-9a-z]", buf);
printf("%s\n", buf);
結果為:123456abcdedf
5. 取到指定字符集為止的字符串。如在下例中,取遇到大寫字母為止的字符串。
sscanf("123456abcdedfBCDEF", "%[^A-Z]", buf);
printf("%s\n", buf);
結果為:123456abcdedf
sscanf("iios/12DDWDFF@122", "%*[^/]/%[^@]", buf);
printf("%s\n", buf);
結果為:12DDWDFF
7、給定一個字符串““hello, world”,僅保留world。(注意:“,”之后有一空格)
printf("%s\n", buf);
結果為:world
%*s表示第一個匹配到的%s被過濾掉,即hello被過濾了
如果沒有空格則結果為NULL。
8、
char *s="1try234delete5"
則:
sscanf(s, "1%[^2]234%[^5]", s1, s2);
scanf的format中出現的非轉換字符(%之前或轉換字符之后的字符),即此例中的1234用來跳過輸入中的相應字符;
‘[]’的含義與正則表達式中相同,表示匹配其中出現的字符序列;^表示相反。使用[ ]時接收輸入的變量必須是有足夠存儲空間的char、signed char、unsigned char數組。記住[也是轉換字符,所以沒有s了。
char s1[4],s2[4],s3[4],s4[4],s5[4],s6[4],s7[4];
sscanf(test,"%[^,],%[^,],%[^,],%[^,],%[^,],%[^,],%[^,]",s1,s2,s3,s4,s5,s6,s7);
printf("sssa1=%s",s1);
printf("sssa2=%s",s2);
printf("sssa3=%s",s3);
printf("sssa4=%s",s4);
printf("sssa5=%s",s5);
printf("sssa6=%s",s6);
printf("sssa7=%s",s7);
9、一個提取用戶個人資料中郵件地址的例子
#include<cstdlib>
#include<cstdio>
using namespace std;
int main()
{
char a[20]={0};
char b[20]={0};
//假設email地址信息以';'結束
sscanf("email:jimmywhr@gmail.com;","%*[^:]:%[^;]",a);
//假設email地址信息沒有特定的結束標志
sscanf("email:jimmywhr@gmail.com","%*[^:]:%s",b);
printf("%s\n",a);
printf("%s\n",b);
system("pause");
return 0;
}
關鍵是"%*[^:]:%[^;]"和"%*[^:]:%s"這兩個參數的問題
%*[^:] 表示滿足"[]"里的條件將被過濾掉,不會向目標參數中寫入值。這里的意思是在
第一個':'之前的字符會在寫入時過濾掉,'^'是表示否定的意思,整個參數翻譯
成白話就是:將在遇到第一個':'之前的(不為':'的)字符全部過濾掉。
: 自然就是跳過':'的意思。
%[^;] 拷貝字符直到遇到';'。
%[ ] 的用法:%[ ]表示要讀入一個字符集合, 如果[ 后面第一個字符是”^”,則表示反意思。
%[^a-z] 讀取不在 a-z 之間的字符串,如果碰到a-z之間的字符則停止,如
%*[^=] 前面帶 * 號表示不保存變量。跳過符合條件的字符串。
%[^=] 讀取字符串直到碰到’=’號,’^’后面可以帶更多字符,如:
以前只是簡單是使用sscanf,卻沒發現其還有如此強大的功能
char str0[100],str1[100],str2[100],str3[100];
sscanf("abcde abc 123 aaa","%s %s %s %s",str0,str1,str2,str3);
結果:str0="abcde" str1="abc" str2 = "123" str3="aaa"
sscanf("abcde abc 123 aaa","abc%s %s %*d %s",str0,str1,str3);
結果:str0="abcde" str1="abc" str3="aaa"
sscanf("abc123 efg456","%4s",str0);
結果:str0="abc1"
sscanf("abc123 efg456a4","%[a-z 1-5]",str0);
結果:str0="abc123 efg45"
sscanf("abc123 efg456a4","%[a-z1-5]",str0);
結果:str0="abc123"
sscanf("ABCTabcZ123 efg456","%[A-P]",str0);
結果:str0="ABC"
sscanf("abc 12345","%[^ ]",str0);
結果:str0="abc"
sscanf("abc 12345","%[^4]",str0);
結果:str0="abc 123"
sscanf("fdaBs 52aB1asdf","%[^4-0]",str0);
結果:str0="fdaBs 5"
sscanf("abc 12345","%[^ ]%[^3]",str0,str1);
結果:str0="abc" str1="12"
sscanf("abc301abc2345","%*[^9-0]%s",str0);
結果:str0="301abc2345"
sscanf("bca@123efg4@5abc","%*[^@]@%[^@]",str0);
結果:str0="123efg4"


