如何用CL_CLB_PARSE_JSON解析json字符串到动态生成的ABAP内表结构里

简介: 如何用CL_CLB_PARSE_JSON解析json字符串到动态生成的ABAP内表结构里

*&---------------------------------------------------------------------*

*& Report  ZTESTDATA

*&

*&---------------------------------------------------------------------*

*&

*&

*&---------------------------------------------------------------------*

REPORT ZJSON_TWITTER.

data: lv_content type string,

     lv_number TYPE i,

     lr_json TYPE REF TO CL_CLB_PARSE_JSON,

     lxstring TYPE xstring,

     lv_converted TYPE string.

lv_content = zcl_jerry_tool=>GET_FILE_CONTENT_BY_PATH( '\\TSHomeServer\TSHome$\i042416\Desktop\12.txt' ).

lxstring   = cl_abap_codepage=>convert_to( lv_content ).

lv_converted = CL_CLB_TOOLS=>XSTRING_TO_STRING( lxstring ).

data: lv_id type string,

     lv_text type string,

     lv_string_table TYPE string_table,

     lr_data TYPE REF TO CL_ABAP_TYPEDESCR,

     lr_indices TYPE REF TO CL_ABAP_TABLEDESCR,

     lrs_user_mentions    TYPE REF TO cl_abap_structdescr,

     lrs_entities         TYPE REF TO cl_abap_structdescr,

     lrs_root             TYPE REF TO cl_abap_structdescr,

     lrt_user_mentions    TYPE REF TO cl_abap_tabledescr,

     ls_comp          TYPE abap_componentdescr,

     lt_components    TYPE abap_component_tab,

     lr_content          TYPE REF TO data.

FIELD-SYMBOLS:  TYPE any.

lr_data = CL_ABAP_TYPEDESCR=>describe_by_data( lv_id ).

lr_indices ?= CL_ABAP_TYPEDESCR=>describe_by_data( lv_string_table ).

ls_comp-name = 'id'.

ls_comp-type ?= lr_data.

APPEND ls_comp TO lt_components.

ls_comp-name = 'id_str'.

ls_comp-type ?= lr_data.

APPEND ls_comp TO lt_components.

ls_comp-name = 'indices'.

ls_comp-type ?= lr_indices.

APPEND ls_comp TO lt_components.

ls_comp-name = 'name'.

ls_comp-type ?= lr_data.

APPEND ls_comp TO lt_components.

ls_comp-name = 'screen_name'.

ls_comp-type ?= lr_data.

APPEND ls_comp TO lt_components.

lrs_user_mentions  = cl_abap_structdescr=>create( lt_components ).

lrt_user_mentions      = cl_abap_tabledescr=>create( lrs_user_mentions ).

CLEAR: lt_components.

ls_comp-name = 'user_mentions'.

ls_comp-type ?= lrt_user_mentions.

APPEND ls_comp TO lt_components.

lrs_entities = cl_abap_structdescr=>create( lt_components ).

CLEAR: lt_components.

ls_comp-name = 'created_at'.

ls_comp-type ?= lr_data.

APPEND ls_comp TO lt_components.

ls_comp-name = 'entities'.

ls_comp-type ?= lrs_entities.

APPEND ls_comp TO lt_components.

ls_comp-name = 'id'.

ls_comp-type ?= lr_data.

APPEND ls_comp TO lt_components.

ls_comp-name = 'text'.

ls_comp-type ?= lr_data.

APPEND ls_comp TO lt_components.

lrs_root = cl_abap_structdescr=>create( lt_components ).

CREATE DATA lr_content TYPE HANDLE lrs_root.

ASSIGN lr_content->* TO .

BREAK-POINT.

CREATE OBJECT lr_json.

CALL METHOD lr_json->JSON_TO_DATA

  EXPORTING

     IV_JSON = lv_converted

  CHANGING

     c_data = .

BREAK-POINT.

相关实践学习
部署高可用架构
本场景主要介绍如何使用云服务器ECS、负载均衡SLB、云数据库RDS和数据传输服务产品来部署多可用区高可用架构。
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
目录
相关文章
|
13天前
|
JSON 安全 Swift
【Swift开发专栏】Swift中的JSON解析与处理
【4月更文挑战第30天】本文介绍了Swift中的JSON解析与处理。首先,讲解了JSON的基础,包括其键值对格式和在Swift中的解析与序列化方法。接着,展示了如何使用`Codable`协议简化JSON操作,以及处理复杂结构的示例。通过这些内容,读者能掌握在Swift中高效地处理JSON数据的方法。
|
13天前
|
分布式计算 DataWorks 关系型数据库
DataWorks产品使用合集之在DataWorks中,使用JSON解析函数将MySQL表中的字段解析成多个字段将这些字段写入到ODPS(MaxCompute)中如何解决
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
27 3
|
13天前
|
存储 JSON DataWorks
DataWorks产品使用合集之DataWorks将 MongoDB 中的数组类型写入到 DataWorks 的单个字段时,表示为字符串格式而非 JSON 格式如何解决
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
26 3
|
14天前
|
JSON 分布式计算 大数据
MaxCompute产品使用合集之大数据计算MaxCompute 要提取JSON字符串中的所有key-value对,我该怎么操作
MaxCompute作为一款全面的大数据处理平台,广泛应用于各类大数据分析、数据挖掘、BI及机器学习场景。掌握其核心功能、熟练操作流程、遵循最佳实践,可以帮助用户高效、安全地管理和利用海量数据。以下是一个关于MaxCompute产品使用的合集,涵盖了其核心功能、应用场景、操作流程以及最佳实践等内容。
|
21天前
|
JSON 前端开发 Java
SpringBoot之JSON参数,路径参数的详细解析
SpringBoot之JSON参数,路径参数的详细解析
17 0
|
21天前
|
JSON 运维 Kubernetes
云效产品使用报错问题之流水线中配置了AppStack,构建时下载的制品内容为json字符串,如何解决
本合集将整理呈现用户在使用过程中遇到的报错及其对应的解决办法,包括但不限于账户权限设置错误、项目配置不正确、代码提交冲突、构建任务执行失败、测试环境异常、需求流转阻塞等问题。阿里云云效是一站式企业级研发协同和DevOps平台,为企业提供从需求规划、开发、测试、发布到运维、运营的全流程端到端服务和工具支撑,致力于提升企业的研发效能和创新能力。
|
26天前
|
JSON 数据格式 Python
py如何把字符串转出json
py如何把字符串转出json
7 0
|
1月前
|
存储 JSON JavaScript
「Python系列」Python JSON数据解析
在Python中解析JSON数据通常使用`json`模块。`json`模块提供了将JSON格式的数据转换为Python对象(如列表、字典等)以及将Python对象转换为JSON格式的数据的方法。
35 0
|
2天前
PandasTA 源码解析(二十三)
PandasTA 源码解析(二十三)
7 0
|
2天前
PandasTA 源码解析(二十二)(3)
PandasTA 源码解析(二十二)
5 0

热门文章

最新文章

推荐镜像

更多