c语言函数库学习~sscanf~格式化输入
---恢復(fù)內(nèi)容開始---
今天算是被打擊到了吧,由鄭輕的acm老師來我學(xué)院指導(dǎo)安排了個現(xiàn)場的小比賽,,俺們居然有還是輸給一個大一的新手,,哎,情何以堪,,所以還是要重視下基礎(chǔ)編程能力的培訓(xùn),現(xiàn)在嘛我就開始學(xué)習(xí)下格式化的輸入,,很復(fù)雜但是很有效果的。。。
sscanf() - 從一個字符串中讀進(jìn)與指定格式相符的數(shù)據(jù).?
Int sscanf( string str, string fmt, mixed var1, mixed var2 ... );?
int scanf( const char *format [,argument]... );?
sscanf與scanf類似,都是用于輸入的,只是后者以屏幕(stdin)為輸入源,前者以固定字符串為輸入源。
參有幾種特殊的符號表示。
? ? ?1、 * 亦可用于格式中, (即 %*d 和 %*s) 加了星號 (*) 表示跳過此數(shù)據(jù)不讀入. (也就是不把此數(shù)據(jù)讀入?yún)?shù)中)?
2、{a|b|c}表示a,b,c中選一,[d],表示可以有d也可以沒有d。?
3、width表示讀取寬度。?
4、{h | l | I64 | L}:參數(shù)的size,通常h表示單字節(jié)size,I表示2字節(jié) size,L表示4字節(jié)size(double例外),l64表示8字節(jié)size。?
5、type :這就很多了,就是%s,%d之類。?
6、特別的:%*[width] [{h | l | I64 | L}]type 表示滿足該條件的被過濾掉,不會向目標(biāo)參數(shù)中寫入值?
支持集合操作:?
%[a-z] 表示匹配a到z中任意字符,貪婪性(盡可能多的匹配)?
%[aB'] 匹配a、B、'中一員,貪婪性?
%[^a] 匹配非a的任意字符,貪婪性?
?
我們可以看看測試數(shù)據(jù)。。
#include<stdio.h>
int main()
{
char buf[10];
sscanf("hello, world","%*s%s",buf);//這里要考慮到%s是到空格結(jié)束,,所以第一個%s就被*忽略了。//sscanf("hello,\\nworld","%*s%s",buf);這里用\\n也是同樣的原來
printf("%s\n",buf);
}
?
sscanf("hello, world", "%5s", buf);獲取前五個字符
當(dāng)然你也會想能不能把數(shù)字做為字符存到數(shù)組中我們來看看、
#include<stdio.h>
#include<string.h>
int main()
{
char buf1[100],buf2[100];
int a;
double b;
scanf("%d",&a);
scanf("%lf",&b);//測試小數(shù)是否可以轉(zhuǎn)
//itoa(a,buf,10);這個函數(shù)也可以實現(xiàn)數(shù)字轉(zhuǎn)字符,10代表進(jìn)制
sprintf(buf1,"%d",a);
sprintf(buf2,"%lf",b);//這里注意他會把點號也輸入
printf("字符型的int :%s\n ",buf1);//這里直接輸出a不過是作為字符的
printf("字符型的doubl :%s\n ",buf2);//同上
printf("int 長度:%d\n",strlen(buf1));//可以用于計算位數(shù)
printf("doubl 長度:%d\n",strlen(buf2));//長度上是包含了點的
}
?
3. 取到指定字符為止的字符串。如在下例中,取遇到空格為止字符串。?
sscanf("123456 abcdedf", "%[^ ]", buf); //"%[^ ]"這里^之后有個空格
printf("%s\n", buf);?
結(jié)果為:123456?
4. 取僅包含指定字符集的字符串。如在下例中,取僅包含1到9和小寫字母的字符串。?
sscanf("123456abcdedfBCDEF", "%[1-9a-z]", buf);?
printf("%s\n", buf);?
結(jié)果為:123456abcdedf?
? 這里的sscanf是針對一串字符找到符合%【1-9a-z】直接存放到buf中,然后然后跳出語句,所以在這個語句中只要遇到不識別的比如 E就會直接結(jié)束,返回
123456
else
123456abcdedf
? ? 如下
5. 取到指定字符集為止的字符串。如在下例中,取遇到大寫字母為止的字符串。?
sscanf("123456abcdedfBCDEF", "%[^A-Z]", buf);?
printf("%s\n", buf);?
結(jié)果為:123456abcdedf?
? ? ?
6、給定一個字符串iios/12DDWDFF@122,獲取 / 和 @ 之間的字符串,先將 "iios/"過濾掉,再將非'@'的一串內(nèi)容送到buf中?
sscanf("iios/12DDWDFF@122", "%*[^/]/%[^@]", buf);?
printf("%s\n", buf);?
結(jié)果為:12DDWDFF?
這里可以用做校驗輸入的是否是標(biāo)準(zhǔn)的郵箱格式,
#include<stdio.h>
int main()
{
char a[100],b[100],c[100],d[100];
int i , j , l ;
scanf("%s",a);
sscanf(a,"%[^@]@%[^.].%s",b,c,d);//這里遇到不是@的一律給b后面類推
printf("%s @ %s . %s\n",b,c,d);
}//最后能夠單獨分離出來就能單獨的處理了。所以不多說
?
7、給定一個字符串““hello, world”,僅保留world。(注意:“,”之后有一空格)?
sscanf(“hello, world”, "%*s%s", buf);?
printf("%s\n", buf);?
結(jié)果為:world?
%*s表示第一個匹配到的%s被過濾掉,即hello被過濾了?
如果沒有空格則結(jié)果為NULL。?
sscanf的功能很類似于正則表達(dá)式, 但卻沒有正則表達(dá)式強(qiáng)大,所以如果對于比較復(fù)雜的字符串處理,建議使用正則表達(dá)式.?
//-------------------------------------------------------?
sscanf,表示從字符串中格式化輸入?
上面表示從str中,輸入數(shù)字給x,就是32700?
久以前,我以為c沒有自己的split string函數(shù),后來我發(fā)現(xiàn)了sscanf;一直以來,我以為sscanf只能以空格來界定字符串,現(xiàn)在我發(fā)現(xiàn)我錯了。?
sscanf是一個運(yùn)行時函數(shù),原形很簡單:?
int sscanf(?
const char *buffer,?
const char *format [,?
argument ] ...?
);?
它強(qiáng)大的功能體現(xiàn)在對format的支持上。?
我以前用它來分隔類似這樣的字符串2006:03:18:?
int a, b, c;?
sscanf("2006:03:18", "%d:%d:%d", a, b, c);?
以及2006:03:18 - 2006:04:18:?
char sztime1[16] = "", sztime2[16] = "";?
sscanf("2006:03:18 - 2006:04:18", "%s - %s", sztime1, sztime2);?
但是后來,我需要處理2006:03:18-2006:04:18?
僅僅是取消了‘-’兩邊的空格,卻打破了%s對字符串的界定。?
我需要重新設(shè)計一個函數(shù)來處理這樣的情況?這并不復(fù)雜,但是,為了使所有的代碼都有統(tǒng)一的風(fēng)格,我需要改動很多地方,把已有的sscanf替換成我自己的分割函數(shù)。我以為我肯定需要這樣做,并伴隨著對sscanf的強(qiáng)烈不滿而入睡;一覺醒來,發(fā)現(xiàn)其實不必。?
format-type中有%[]這樣的type field。如果讀取的字符串,不是以空格來分隔的話,就可以使用%[]。?
%[]類似于一個正則表達(dá)式。[a-z]表示讀取a-z的所有字符,[^a-z]表示讀取除a-z以外的所有字符。?
所以那個問題也就迎刃而解了:?
sscanf("2006:03:18 - 2006:04:18", "%[0-9,:] - %[0-9,:]", sztime1, sztime2);
?
?最后還有個原創(chuàng)的測試。如果我想判斷第一個是不是我需要的元素,那么可以使用|或|的操作,那么要怎么寫代碼呢。
#include<stdio.h>
int main()
{
char buf[10]={0},buf1[10]={0};
sscanf("hello,world","%[{h}]%[{e}]s",buf,buf1);
printf("%s\n%s",buf,buf1);
}
這里要注意因為如果你的%[{e}]中的e寫的是l的話是沒有任何答案的,因為讀取到e的時候沒有對應(yīng)的代碼所以就會直接跳過。或者說是停止讀取。
?
?
?
---恢復(fù)內(nèi)容結(jié)束---
轉(zhuǎn)載于:https://www.cnblogs.com/luyi14/p/4100301.html
總結(jié)
以上是生活随笔為你收集整理的c语言函数库学习~sscanf~格式化输入的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: OC中的NSArray和NSMutabl
- 下一篇: LC并联谐振回路