input中加問(wèn)號(hào)的的作用

對(duì)于初學(xué)SAS的人來(lái)說(shuō),在處理數(shù)據(jù)的時(shí)候,經(jīng)常會(huì)遇到一些“不尋常”的處理。

例如,我們?cè)趯?shù)據(jù)從字符型轉(zhuǎn)換成數(shù)值型時(shí),一般會(huì)這樣處理:

a=input(b,best.)

但是有時(shí)候我們會(huì)看到有這樣的寫法:

a=input(b,??best.)

這里的問(wèn)號(hào)的作用是什么呢?下面我就將通過(guò)實(shí)例帶你們了解問(wèn)號(hào)的作用。

第一步:輸入數(shù)據(jù)。

data test;

????input id score $;

cards;

01 96a

02 67

03 89c

04 58

05 99

;

run;

第二步:將變量score轉(zhuǎn)換成數(shù)值型。

data test2;

set test;

score2=input(score,best.);

run;

可以看到對(duì)于不規(guī)范的數(shù)據(jù),SAS將值變?yōu)榭眨瑫r(shí)log中報(bào)錯(cuò),這在項(xiàng)目中是不允許的。

第三步:在input中加入問(wèn)號(hào)。

對(duì)于無(wú)效的數(shù)據(jù),SAS將值轉(zhuǎn)換為空值,同時(shí)log中并沒(méi)有報(bào)錯(cuò)。

data test3;

set test;

score2=input(score,??best.);

run;

從上面的例子中我們可以看出,??的作用就是將無(wú)效的數(shù)據(jù)轉(zhuǎn)換為空值,同時(shí)不會(huì)在log窗口輸出錯(cuò)誤信息。不管是在將字符型數(shù)據(jù)轉(zhuǎn)換為數(shù)值型還是說(shuō)日期轉(zhuǎn)換的時(shí)候,用??都能防止出現(xiàn)那種狀況。

其實(shí)還有只用一個(gè)?的情況,但是我覺(jué)得和不輸入問(wèn)號(hào)的結(jié)果都是一樣的,還會(huì)報(bào)錯(cuò),只是報(bào)的錯(cuò)誤不一樣罷了。具體的你們自己可以去試試。下面附上?和??的英文解釋:

???modifier suppresses the invalid data message.

?? modifier also suppresses the invalid data message and prevents setting _error_ to 1 for invalid data.

在實(shí)際應(yīng)用中,適當(dāng)運(yùn)用這種方法能有效防止log報(bào)錯(cuò),因?yàn)楫?dāng)我們從DM那獲取的數(shù)據(jù),有時(shí)候可能是“臟數(shù)據(jù)”。至于要不要將數(shù)據(jù)轉(zhuǎn)換為空值,要根據(jù)具體項(xiàng)目而定。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容