0

0

Sublime如何快速将JSON键名提取为数组?(数据处理技巧)

穿越時空

穿越時空

发布时间:2026-02-23 11:41:02

|

810人浏览过

|

来源于php中文网

原创

sublime text可用正则"(1+)"\s:提取json所有键名,替换为"$1",;需勾选regex、关闭自动补全;顶层键可配合折叠或^\s"(1+)"\s*:;最后补方括号、删末逗号得合法js数组。" ↩

sublime如何快速将json键名提取为数组?(数据处理技巧)

用正则批量提取 JSON 键名(Sublime 原生支持)

Sublime Text 本身不带“JSON 键转数组”按钮,但靠自带的正则查找替换就能一步到位。关键不是写新插件,而是找准键名在 JSON 中的文本模式。

常见错误是直接搜 "\w+": —— 这会漏掉带中划线、数字开头、空格或 Unicode 的键(比如 "user-id""2fa_enabled""昵称"),也会误中字符串值里的引号内容。

  • 正确正则模式:"([^"]+)"\s*:(匹配所有双引号包裹、后紧跟冒号的键名)
  • 替换为:"$1",(保留引号,加英文逗号,方便后续拼成数组)
  • 务必勾选 RegexJSON 模式下关闭自动补全(避免替换时触发格式化把换行吃掉)

处理嵌套对象和数组边界(避免多层键名混在一起)

如果 JSON 里有嵌套对象或数组,比如 {"user": {"name": "a", "age": 20}},默认正则会把 "user""name""age" 全提出来——但你可能只要顶层键。

这时得靠 Sublime 的 折叠功能辅助限定范围:先折叠所有子对象(Ctrl+Shift+[),再对展开的顶层做查找替换;或者用更保守的正则:^\s*"([^"]+)"\s*:(加 ^\s* 确保是行首缩进后的键)。

讯飞听见会议
讯飞听见会议

科大讯飞推出的AI智能会议系统

下载
  • 嵌套越深,纯正则越难区分层级——别硬刚,先手动折叠再操作更稳
  • 如果目标是“所有键(无论层级)”,就用第一个正则,但替换后要人工删重复项
  • 注意数组项([{...}, {...}])内部的键也会被扫到,如不需要,提前删掉数组部分或加负向断言(但 Sublime 正则不支持 (?!...),慎用)

生成合法 JavaScript 数组(补括号、去末尾逗号)

替换完得到一堆 "key1", "key2", "key3",,但末尾多一个逗号,直接粘贴进 JS 会报 SyntaxError: Unexpected token ','

  • 替换第二步:搜 ,\s*$(行尾逗号),替为空,解决语法错误
  • 再手动在开头加 [",结尾加 "],或用多光标:按住 Ctrl 点两头,输入括号
  • 如果键名含双引号或反斜杠(极少见但 JSON 允许),"([^"]+)" 会截断——此时必须改用 JSON 解析器,Sublime 正则无解

为什么不用在线工具或 Python 脚本?

临时处理小 JSON(几百行内),Sublime 正则比切窗口、粘贴、等加载、再复制快得多。但一旦遇到以下情况,就该停手换工具:

  • JSON 格式不合法(缺引号、注释、尾逗号)——Sublime 查找不报错,但结果错得无声无息
  • 需要过滤键名(比如只要以 is_ 开头的)、或按值类型筛选(只提 string 类型的键)——正则做不到语义判断
  • 要批量处理多个文件——写个 jq 命令一行搞定:jq 'paths(scalars) | select(length > 0) | join(".")' file.json

真正卡住人的往往不是正则怎么写,而是没意识到 JSON 文本里那些看似无关的空格、换行、注释,会让 "([^"]+)"\s*: 匹配失败——建议先用 Ctrl+Shift+PJSON: Reindent 整理格式再动手。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

446

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

544

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

322

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

81

2025.09.10

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

830

2023.08.02

登录token无效
登录token无效

登录token无效解决方法:1、检查token的有效期限,如果token已经过期,需要重新获取一个新的token;2、检查token的签名,如果签名不正确,需要重新获取一个新的token;3、检查密钥的正确性,如果密钥不正确,需要重新获取一个新的token;4、使用HTTPS协议传输token,建议使用HTTPS协议进行传输 ;5、使用双因素认证,双因素认证可以提高账户的安全性。

6433

2023.09.14

登录token无效怎么办
登录token无效怎么办

登录token无效的解决办法有检查Token是否过期、检查Token是否正确、检查Token是否被篡改、检查Token是否与用户匹配、清除缓存或Cookie、检查网络连接和服务器状态、重新登录或请求新的Token、联系技术支持或开发人员等。本专题为大家提供token相关的文章、下载、课程内容,供大家免费下载体验。

837

2023.09.14

token怎么获取
token怎么获取

获取token值的方法:1、小程序调用“wx.login()”获取 临时登录凭证code,并回传到开发者服务器;2、开发者服务器以code换取,用户唯一标识openid和会话密钥“session_key”。想了解更详细的内容,可以阅读本专题下面的文章。

1087

2023.12.21

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

1030

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 9.5万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号