PROC GROOVY 解析JSON

來源:互聯網
上載者:User

標籤:card   nes   idcard   one   尋找   class   bsp   header   代碼   

 

 

參考:http://saslist.com/blog/category/json/

下載jdk和groovy
1.安裝jdk 預設安裝
2解壓groovy:到C:\Program Files (x86)\
參照http://saslist.com/blog/category/json/ 關於groovy的那段,配置groovy,並設定系統變數:
**********
(1)JDK的配置:
設定環境變數%JAVA_HOME%\bin,值為放置解壓檔案的目錄,如C:\Program Files (x86)\Java\jdk1.8.0_141
增加環境變數path,指向%GROOVY_HOME%\bin
(2)groovy配置
設定環境變數GROOVY_HOME,值為放置解壓檔案的目錄,如C:\Program Files (x86)\groovy-2.4.12
增加環境變數path,指向%GROOVY_HOME%\bin
(3)找到SAS執行程式的路徑,如C:\Program Files\SASHome\SASFoundation\9.4
該路徑下的\nls\en的sasv9.cfg,尋找JREOPTIONS,添加
-Dtkj.app.class.path=C:\Program Files (x86)\Groovy\groovy-2.4.12\embeddable\groovy-all-2.4.12.jar

3將解析結果放在csv裡面,需要將opencsv-3.10放在groovy安裝包下面embeddable下面

4.接下來就可以在Groovy控制台中編寫指令碼了,在Windows控制台(cmd)下輸入groovyconsole命令進入groovy控制台,在裡面輸入代碼 println "HelloWorld"斷行符號,按按鍵組合CTRL+R就可以看到運行結果了。

解析:

json:

{
"acct_nbr": 1234,
"firstName": "John",
"lastName": "Smith",
"age": 25,
"address": {
"streetAddress": "21 2nd Street",
"city": "New York",
"state": "NY",
"postalCode": "10021"
}
}
,
{
"acct_nbr": 3456,
"firstName": "Sam",
"lastName": "Jones",
"age": 32,
"address": {
"streetAddress": "25 2nd Street",
"city": "New Jersy",
"state": "NJ",
"postalCode": "10081"
}
}

解析代碼:


%let groovydir=C:\Program Files (x86)\groovy-2.4.12\embeddable; *the location the groovy JARs are located at;

%let sourcefile=.\data\test_1.txt;
%let outfile=.\data\test_1.csv;

proc groovy classpath="&groovydir.\groovy-all-2.4.12.jar;&groovydir.\opencsv-3.10.jar";

submit "&sourcefile" "&outfile";
import groovy.json.*/*載入json包*/
import com.opencsv.*

def input = new File(args[0]).text
def output = new JsonSlurper().parseText(input)
def csvoutput = new FileWriter(args[1])

CSVWriter writer = new CSVWriter(csvoutput);

String[] header = new String[2];
header[0] = "user_basic";
header[1] = "user_blacklist";
writer.writeNext(header);

output.statuses.each {
String[] user_basic_content1 = new String[8];
content[0] = it.user_basic.user_age.toString();
content[1] = it.user_basic.user_city.toString();
content[2] = it.user_basic.user_gender.toString();
content[3] = it.user_basic.user_idcard.toString();
content[4] = it.user_basic.user_idcard_valid.toString();
content[5] = it.user_basic.user_name.toString();
content[6] = it.user_basic.user_phone.toString();
content[7] = it.user_basic.user_phone_city.toString();
writer.writeNext(user_basic_content1);
}

writer.close();

endsubmit;
quit;

PROC GROOVY 解析JSON

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.