-
缱绻 数据领袖Lv6
发表于2020-8-5 15:03
楼主
本帖最后由 缱绻 于 2020-8-5 15:05 编辑
接口数据,有5个头部参数,4个body参数,配置方法:
step1:5个头部参数分别添加,头部参数属性选择“是”
step2:body参数有endPeriod、pk_corp、pk_glorgbook、startPeriod
新增参数,参数名称为“空格”;
头部参数设置为“否”;
参数默认值为{"endPeriod":"2020-06","pk_corp":"02","pk_glorgbook":"02-2018L","startPeriod":"2020-06"}
step3:获取到的数据格式大致如下
step4:通过接口数据源创建接口主题表
通过step3可以看到目前获取到的data里面的格式不符合接口主题表需要的数据格式
那么就需要脚本去进行格式的转换,转换为类似[{index : 1, name : zhao}]的son数组;
脚本如下:
复制代码
接口数据,有5个头部参数,4个body参数,配置方法:
step1:5个头部参数分别添加,头部参数属性选择“是”
step2:body参数有endPeriod、pk_corp、pk_glorgbook、startPeriod
新增参数,参数名称为“空格”;
头部参数设置为“否”;
参数默认值为{"endPeriod":"2020-06","pk_corp":"02","pk_glorgbook":"02-2018L","startPeriod":"2020-06"}
step3:获取到的数据格式大致如下
step4:通过接口数据源创建接口主题表
通过step3可以看到目前获取到的data里面的格式不符合接口主题表需要的数据格式
那么就需要脚本去进行格式的转换,转换为类似[{index : 1, name : zhao}]的son数组;
脚本如下:
- function getQueryJson(queryData) {
- queryData = JSON.parse(queryData);
- var array = format(queryData.data,true);
- parseData = JSON.parse(array);
- array = parseData.datas;
- return JSON.stringify(array);
- }
- function format(txt, compress /*是否为压缩模式*/ ) { /* 格式化JSON源码(对象转换为JSON文本) */
- var indentChar = ' ';
- if (/^\s*$/.test(txt)) {
- alert('数据为空,无法格式化! ');
- return;
- }
- try {
- var data = eval('(' + txt + ')');
- } catch (e) {
- alert('数据源语法错误,格式化失败! 错误信息: ' + e.description, 'err');
- return;
- };
- var draw = [],
- last = false,
- This = this,
- line = compress ? '' : '\n',
- nodeCount = 0,
- maxDepth = 0;
- var notify = function(name, value, isLast, indent /*缩进*/ , formObj) {
- nodeCount++; /*节点计数*/
- for (var i = 0, tab = ''; i < indent; i++) tab += indentChar; /* 缩进HTML */
- tab = compress ? '' : tab; /*压缩模式忽略缩进*/
- maxDepth = ++indent; /*缩进递增并记录*/
- if (value && value.constructor == Array) { /*处理数组*/
- draw.push(tab + (formObj ? ('"' + name + '":') : '') + '[' + line); /*缩进'[' 然后换行*/
- for (var i = 0; i < value.length; i++)
- notify(i, value[i], i == value.length - 1, indent, false);
- draw.push(tab + ']' + (isLast ? line : (',' + line))); /*缩进']'换行,若非尾元素则添加逗号*/
- } else if (value && typeof value == 'object') { /*处理对象*/
- draw.push(tab + (formObj ? ('"' + name + '":') : '') + '{' + line); /*缩进'{' 然后换行*/
- var len = 0,
- i = 0;
- for (var key in value) len++;
- for (var key in value) notify(key, value[key], ++i == len, indent, true);
- draw.push(tab + '}' + (isLast ? line : (',' + line))); /*缩进'}'换行,若非尾元素则添加逗号*/
- } else {
- if (typeof value == 'string') value = '"' + value + '"';
- draw.push(tab + (formObj ? ('"' + name + '":') : '') + value + (isLast ? '' : ',') + line);
- };
- };
- var isLast = true,
- indent = 0;
- notify('', data, isLast, indent, false);
- return draw.join('');
- }