1

Vivaldi 浏览器(基于 Chromium)的书签文件往往会积累大量 base64 编码的缩略图,占用大量空间,我想删除这些条目。该文件是一个 JSON 文件,条目如下所示:

{
  "date_added": "13215828073144281",
  "guid": "3ace3174-ea60-42c5-88cf-e535a150ae38",
  "id": "74",
  "meta_info": {
     "Thumbnail": "....AUpSgFKUoBSlKA//2Q=="
  },
  "name": "RIPE WHOIS IP Address Database Search › Look up an IP addres… - iTools",
  "type": "url",
  "url": "http://itools.com/tool/ripe-whois-ip-address"
},

我已经有一个看起来像这样的 jq 过滤器:

jq 'walk(if type == "object" then with_entries(select(.key | test("Thumbnail") | not)) else . end)' Bookmarks > Bookmarks2

问题是这也会删除包含自定义缩略图的条目,如下所示:

"Thumbnail": "chrome://vivaldi-data/local-image/aa0d8713-99c6-4fcb-a725-a29235c4e8b0",

所以问题是,我将如何删除包含或以字符串开头的缩略图条目data:image

4

2 回答 2

2

这样的事情应该可以解决问题:

del(recurse | objects | select(has("Thumbnail")) .Thumbnail | select(startswith("data:image")))
于 2021-10-16T13:45:20.277 回答
1

您可以添加另一个约束startswith("data:image") | notselect仅保留.key不匹配的元素,其不or.value这种方式开始,从而导致:select((.key | test("Thumbnail") | not) or (.value | startswith("data:image") | not))。您甚至可以应用德摩根定律并将其简化为select(((.key | test("Thumbnail")) and (.value | startswith("data:image"))) | not).

但是,有一个更简单的方法:假设整体结构是一个数组

[
  {
    "date_added": "13215828073144281",
    "guid": "3ace3174-ea60-42c5-88cf-e535a150ae38",
    ...
  },
  {
    "date_added": "13215828073144282",
    "guid": "3ace3174-ea60-42c5-88cf-e535a150ae39",
    ...
  },
  ...
]

然后只需调用

jq 'map(del(.meta_info.Thumbnail | select(startswith("data:image"))))' Bookmarks
于 2021-10-16T13:43:30.853 回答