首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >NotePad ++提取单词[]

NotePad ++提取单词[]
EN

Stack Overflow用户
提问于 2017-12-21 08:24:14
回答 1查看 1.7K关注 0票数 1

对于当前的任务,我的NotePad++文件中有如下所示的JSON数据,

代码语言:javascript
复制
   "hits": {
      "total": 85,
      "max_score": 1,
      "hits": [
         {
            "_index": "mycluster",
            "_type": "subjectData",
            "_id": "24",
            "_score": 1,
            "fields": {
               "CaseA": [
                  "Personal and Culinary Services"
               ]
            }
         },
         {
            "_index": "mycluster",
            "_type": "subjectData",
            "_id": "30",
            "_score": 1,
            "fields": {
               "CaseA": [
                  "na"
               ]
            }
         },
         {
            "_index": "mycluster",
            "_type": "subjectData",
            "_id": "31",
            "_score": 1,
            "fields": {
               "CaseA": [
                  "Agriculture, Agriculture Operations, and Related Sciences"
               ]
            }
         }
      ]    
}

我需要从整个文件中单独提取CaseA值,

代码语言:javascript
复制
"CaseA": [
            "Personal and Culinary Services"
         ]

比如“个人和烹饪服务”。

有没有办法这样做,“CaseA”:1美元??

任何帮助/建议/想法都是有用的。

EN

回答 1

Stack Overflow用户

发布于 2017-12-21 08:34:40

Notepad++是解析JSON的一个特别糟糕的工具。JSON解析器会好得多,但我们可以尝试编写一个正则表达式:

查找:

代码语言:javascript
复制
(?:(?!"CaseA":).)*("CaseA":\s+\[[^\]]*\])

替换:

代码语言:javascript
复制
$1\n

上面模式的基本思想是在文本"CaseA":开始之前使用所有东西。此时,我们使用并捕获CaseA文本。在替换中,我们只使用要保留的文本。

我还没有在Notepad++中测试这一点,但是匹配在下面的演示中确实有效。

Demo

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47920803

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档