sas 解析json
代码:
proc ds2;
data _null_;
method init();
dcl package json j();
dcl int rc tokenType parseFlags;
dcl bigint lineNum colNum;
dcl nvarchar(128) token abc t1;
abc = 'xyz';
t1 = '{"abc" : 1 }';
rc = j.createParser( t1 );
if (rc ne 0) then goto TestError;
* obj open;
j.getNextToken( rc, token, tokenType, parseFlags, lineNum, colNum );
if ( rc ne 0 ) then goto TestError;
PUT "1、" rc= token= tokenType= parseFlags= lineNum= colNum= ;
* obj label;
j.getNextToken( rc, token, tokenType, parseFlags, lineNum, colNum );
if ( rc ne 0 ) then goto TestError;
PUT "2、" rc= token= tokenType= parseFlags= lineNum= colNum= ;
* obj value;
j.getNextToken( rc, token, tokenType, parseFlags, lineNum, colNum );
if ( rc ne 0) then goto TestError;
PUT "3、" rc= token= tokenType= parseFlags= lineNum= colNum= ;
* obj close;
j.getNextToken( rc, token, tokenType, parseFlags, lineNum, colNum );
if ( rc ne 0 ) then goto TestError;
PUT "4、" rc= token= tokenType= parseFlags= lineNum= colNum= ;
Exit:
rc = j.destroyParser();
return;
TestError:
put 'Test ended abnormally.';
goto Exit;
end;
enddata;
run;
quit;
运行日记:
. rc=0 token={ tokenType=64 parseFlags=0 lineNum=1 colNum=1
. rc=0 token=abc tokenType=256 parseFlags=1 lineNum=1 colNum=6
. rc=0 token=1 tokenType=512 parseFlags=3 lineNum=1 colNum=10
. rc=0 token=} tokenType=128 parseFlags=0 lineNum=1 colNum=12
GETNEXTTOKEN Method
Returns the next validated JSON language item or element from the JSON text.
Syntax
Form 1:
package.GETNEXTTOKEN (rc, token-type, parse-flags,);
Form 2:
package.GETNEXTTOKEN (rc, token, token-type, parse-flags,);
Form 3:
package.GETNEXTTOKEN (rc, token, token-type, parse-flags, line-number,
column-number);
Arguments
package
specifies an instance of the JSON package.
rc
specifies the variable to hold the return code value. Possible return code values are as follows:
0 Success
100 The output token argument's maximum length was not large enough and truncation occurred.
101 Done. Depending on the use case, this might or might not be expected.
300 End of text. Depending on the use case, this might or might not be expected.
301 An error occurred while parsing the text.
token-type
token-type can be one of the following values:
4 Boolean true
8 Boolean false
16 Left bracket ( [ )
32 Right bracket ( [ )
64 Left brace ( { )
128 Right brace ( } )
256 String
512 Numeric
1024 Null
parse-flags
parse-flags output value can be an integer flag set consisting of one or more of the following flags:
0x00000001 token is a label in an object
0x00000002 token is not complete
0x00000003 token is an integral numeric
0x00000004 token is a floating point number
token
is the next token or string.
line-number
Updates the given integer variable argument with the line number within the text where the token is located.
Tip You can use the line number to help determine the location of the token within the text.
column-number
Updates the given integer variable argument with the column number within the text where the token is located.
Tip You can use the column number to help determine the location of the token within the text.
Details
All of the arguments to the GETNEXTTOKEN method are passed by reference.
You can use the IS* methods to test the token type.
sas 解析json的更多相关文章
- Xamarin.Android下获取与解析JSON
一.新建项目 1.新建一个Android项目,并命名为为NetJsonList 2.右击引用,选择添加引用,引用System.Json.dll 二.同步请求 既然是跨平台,我们自然不能按照java下的 ...
- 使用Newtonsoft.Json.dll(JSON.NET)动态解析JSON、.net 的json的序列化与反序列化(一)
在开发中,我非常喜欢动态语言和匿名对象带来的方便,JSON.NET具有动态序列化和反序列化任意JSON内容的能力,不必将它映射到具体的强类型对象,它可以处理不确定的类型(集合.字典.动态对象和匿名对象 ...
- 阶段一:通过网络请求,获得并解析JSON数据(天气应用)
“阶段一”是指我第一次系统地学习Android开发.这主要是对我的学习过程作个记录. 在上一篇阶段一:解析JSON中提到,最近在写一个很简单的天气预报应用.即使功能很简单,但我还是想把它做成一个相对完 ...
- 阶段一:解析JSON
“阶段一”是指我第一次系统地学习Android开发.这主要是对我的学习过程作个记录. 最近学到解析JSON格式的网络数据,而作业也要求自己找一个天气预报的API地址,然后解析其中JSON格式的数据.可 ...
- C语言创建及解析Json的使用法则
参考原文:http://blog.csdn.net/xukai871105/article/details/33013455 JSON(JavaScriptObject Notation)是一种轻量级 ...
- 不一样的dynamic解析json 万能方法
写过javascript的人都知道js解析json 1:(JSON) 字符串转换为对象. var str = '{"name":"lsw","hobb ...
- C# 解析JSON的几种办法
欲成为海洋大师,必知晓海中每一滴水的真名. 刚开始只是想找一个转换JSON数组的方法,结果在MSDN翻到一大把. 搜索过程中免不了碰到一大堆名词:WCF => DataContract => ...
- eval解析JSON中的注意点
在JS中将JSON的字符串解析成JSON数据格式,一般有两种方式: 1.一种为使用eval()函数. 2. 使用Function对象来进行返回解析. 使用eval函数来解析,并且使用jquery ...
- C#解析json文件的方法
C# 解析 json JSON(全称为JavaScript Object Notation) 是一种轻量级的数据交换格式.它是基于JavaScript语法标准的一个子集. JSON采用完全独立于语言的 ...
随机推荐
- 关于 php 和 python 的浮点计算 0.1+0.2
关于 php 和 python 的浮点计算 0.1+0.2 看到群里有小伙伴说为什么 python 计算出 0.1+0.2 是 0.30000000000000004 >>> pri ...
- 自建mail服务器之二:hmailserver
具体参考: http://blog.xuite.net/sendohshih/blog/41958216-3%E5%88%86%E9%90%98%E8%BC%95%E9%AC%86%E6%93%81% ...
- 在vue-cli 2.x 项目中,引入stylus的全局CSS变量
出处:https://blog.csdn.net/weixin_39378610/article/details/81140358
- virtualBox 虚拟机下nginx设置不缓存静态文件不起作用解决办法
最近开发的时候,调整js时会一直使用缓存文件,无法显示改动!nginx配置静态文件add_header Cache-Control no-cache;也不起作用,很苦恼! nginx配置代码:even ...
- Scrapy 设置请求头
爬虫的过程有些网站设置反盗链,需要我们在请求头中添加下,修改settings.py文件中添加 DEFAULT_REQUEST_HEADERS = { 'Accept': 'text/html,appl ...
- Go hashcode 输入一个字符串,得到一个唯一标识码
如何输入一个字符串,得到一个唯一的hashcode? 例子如下: package main import ( "fmt" "hash/crc32" ) // S ...
- python和linux如何学习一门新的编程语言(python)(python基础结构)
1.python 开发 1.1基础 python,java语言优势:可以写网页+后台功能,python开发效率高,执行效率低,java执行效率高,开发效率低 环境变量配置:进入--->控制面板\ ...
- vlan交换机的端口模式有哪几种
一 端口类型1 ,Access用户模式2 ,Trunk链路模式3 ,Hybrid模式(跟Trunk很类似但比trunk高级)二 端口介绍2.1 ,Access类型端口:只允许默认vlan的以太网帧,也 ...
- npm yarn安装包
- C++进阶--静态初始化的惨败
/* Initialization Fiasco 一个会使程序崩溃的细微的问题 */ // 不同文件的编译顺序是不确定的 // 如果一个文件依赖另一个文件的对象先初始化,可能出现问题 // 解决方法: ...