powerbuilder 如何解析JSON字符串

PowerBuilder没有内建的JSON解析功能,但可以通过使用PowerScript的字符串函数和数据类型来解析JSON字符串。

以下是一种可能的解析方法:

首先,将JSON字符串转换为PowerBuilder字符串变量。

例如,假设有一个JSON字符串:

json 复制代码
{
  "name": "John Smith",
  "age": 30,
  "city": "New York"
}

可以将其转换为PowerBuilder字符串变量,例如:

powerbuilder 复制代码
string ls_json
ls_json = '{ "name": "John Smith", "age": 30, "city": "New York" }'

使用PowerScript的字符串函数解析JSON字符串。

可以使用PowerScript的字符串函数(例如PosMidReplace)来解析JSON字符串中的键值对。例如,可以使用Pos函数找到某个键的位置,然后使用Mid函数提取该键对应的值。

powerbuilder 复制代码
integer li_start, li_end

// 查找"name"键的位置
li_start = Pos('name', ls_json)
li_start = li_start + 6 // 跳过键名和冒号字符

// 查找值的结束位置
li_end = Pos('"', ls_json, li_start) - 1

// 提取值
string ls_name
ls_name = Mid(ls_json, li_start, li_end - li_start)

重复步骤2,解析其他键值对。

根据需要,可以重复步骤2,解析JSON字符串中的其他键值对。

请注意,这只是一种可能的解析方法,可以根据实际需求和JSON字符串的结构进行调整。另外,如果需要处理更复杂的JSON结构,可能需要使用循环和递归。

首先可以告诉大家目前基本上没有很好的方案,虽然网上有人提供一些json解析对象实际上仅仅适用于很小体积的JSON,对于大的JSON字符串会很慢或者干脆卡死,在实际项目我只能实话说我们一般使用后台数据库自带的解析功能进行解析但是这样就涉及到前后数据传输的问题如果碰到比较特殊的符号就会有麻烦,所以很抱歉的说目前没有很好解决方案。

相关推荐
kyriewen1 天前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
IT_陈寒1 天前
Java的Date类又坑了我一次,改用时间戳真香
前端·人工智能·后端
小林攻城狮1 天前
使用 Transport 节流解决 Vercel AI SDK 流式渲染卡死问题
前端·react.js
前端缘梦1 天前
告别 TS 运行时类型漏洞!Zod 完整入门实战教程(前端 / 全栈必备)
前端·react.js·全栈
the_answer1 天前
Webpack vs Vite 深度对比分析
前端·webpack
转转技术团队1 天前
验证码识别实战:前端不写页面,改训模型了?
前端
MomentYY1 天前
Temperature:AI 的“脑洞旋钮”
前端·llm·ai编程
远航_1 天前
OpenSpec 完整详细介绍
前端·后端
召钱熏1 天前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端
SkyWalking中文站1 天前
认识 Horizon UI · 1/17:SkyWalking 新一代可观测性控制台
运维·前端·监控