找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 16186|回复: 4

[问题求助] 【已解决】利用powershell取json同组下的某一键的值

[复制链接]
发表于 2022-5-8 09:51:01 | 显示全部楼层 |阅读模式
本帖最后由 5i365 于 2022-5-15 09:07 编辑

我只知道JSON文件中的 album_id album_audio_id 两个值, 想利用这两个值, 来获取同一组下的hash键的值, 求路过高手帮忙, 提前感谢

$album_id=37376237
$album_audio_id=255787470

________________________________________________________________JSON文件内容
{
    "data": {
        "timestamp": 1651972245,
        "total": 44,
        "info": [
            {
                "hash": "A5D06A9BD3CC35FF866522F955C095C0",
                "album_id": "37376237",
                "album_audio_id": 255787470,
                "trans_param": {
                    "sort": 42,
                    "cpy_grade": 5,
                    "classmap": {
                        "attr0": 100798472
                    },
                    "cid": 98259926,
                },
                "filename": "汪苏泷 - 不分手的恋爱",
            },
            {
                "hash": "31DFACD6F8CD5A73EA087DD7197BA9D7",
                "album_id": "37376237",
                "album_audio_id": 174466641,
                "trans_param": {
                    "sort": 43,
                    "cpy_grade": 5,
                    "classmap": {
                        "attr0": 100798472
                    },
                    "cid": 98259995,
                },
                "filename": "汪苏泷 - 你让我懂",
            },
            {
                "hash": "48E55ADA95ECA6E5EA4EEC58E22D94DD",
                "album_id": "37376237",
                "album_audio_id": 174452241,
                "trans_param": {
                    "sort": 44,
                    "cpy_grade": 5,
                    "classmap": {
                        "attr0": 100798472
                    },
                    "cid": 98259994,
                },
                "filename": "汪苏泷 - 小星星",
            }
        ]
    },
    "errcode": 0,
    "status": 1,
    "error": ""
}
发表于 2022-5-8 15:21:26 | 显示全部楼层
  1. cls
  2. #查找数据
  3. $album_id=37376237
  4. $album_audio_id=255787470
  5. #解析json
  6. $json = (Get-Content '1.json' -Raw) -replace '(?s),(?=\s*\})','' | ConvertFrom-Json
  7. $json.data.info | Where-Object { $_.album_id -eq $album_id -and $_.album_audio_id -eq $album_audio_id } | foreach {
  8.     $_.hash
  9. }
复制代码

评分

参与人数 1技术 +1 收起 理由
5i365 + 1 技术牛X, 乐于分享

查看全部评分

 楼主| 发表于 2022-5-8 17:33:13 | 显示全部楼层
$json = (Get-Content '1.json' -Raw) -replace '(?s),(?=\s*\})',''

大侠,请教一下, 这个替换不加, 好像也能取到值, 不用有什么别的影响吗?
发表于 2022-5-8 17:50:31 | 显示全部楼层
回复 3# 5i365


    可能是你一楼截取的文本和你的json内容不一样,json对象的最后一个属性结束有多余的逗号
 楼主| 发表于 2022-5-8 18:37:34 | 显示全部楼层
回复 4# went


   明白了, 多谢
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-17 04:13 , Processed in 0.019180 second(s), 9 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表