为了账号安全,请及时绑定邮箱和手机立即绑定

从 JSON 数据内的特定字段中删除单引号字符

从 JSON 数据内的特定字段中删除单引号字符

C#
动漫人物 2023-08-20 15:44:26
下面有这个 json 数据字符串,我需要对其进行一些清理,然后才能反序列化为 C# 中的对象。这是我的 json 字符串:{'data':[     {'ID':'01','Name':'Name 1','Description':'abc','Skills':[{'Type':'abc','Technical':'abc','Description':'abc'}],'Status':false,'Inactive':0},     {'ID':'02','Name':'Name 2','Description':'abc','Skills':[{'Type':'abc','Technical':'abc','Description':'abc'}],'Status':false,'Inactive':0},     {'ID':'03','Name':'Name 3','Description':'abc','Skills':[{'Type':'abc','Technical':'abc','Description':'abc'}],'Status':false,'Inactive':1}]}我想要做的是从上述数据的以下字段中删除单引号(')字符:'Skills':[{'Type':'abc','Technical':'abc','Description':'abc'}]所以我需要实现的是让“技能”字段看起来像这样:'Skills':[{Type:abc,Technical:abc,Description:abc}]我设计了这个正则表达式模式:(?<='Skills':\[\{)(.*?)(?=\}\],)它与下面的字符串匹配,但我不知道如何排除单引号。'Type':'abc','Technical':'abc','Description':'abc'有人可以帮忙吗?
查看完整描述

1 回答

?
拉风的咖菲猫

TA贡献1995条经验 获得超2个赞

最好修改源以获得格式漂亮的 JSON,它不是标准 JSON 格式。


如果您无权修改源输出,可以使用以下命令:


        string content = Console.ReadLine();


        var matchResult = new Regex("(?<='Skills':).*?}]").Matches(content);


        foreach(Match match in matchResult)

        {

            string matchValueWithoutSingleQuote = match.Value.Replace("'", string.Empty);

            content = content.Replace(match.Value, matchValueWithoutSingleQuote);

        }

        Console.WriteLine(content);

        Console.ReadLine();

输出是:


{'data':[

    {'ID':'01','Name':'Name 1','Description':'abc','Skills':[{Type:abc,Technical:abc,Description:abc}],'Status':false,'Inactive':0},

    {'ID':'02','Name':'Name 2','Description':'abc','Skills':[{Type:abc,Technical:abc,Description:abc}],'Status':false,'Inactive':0},

    {'ID':'03','Name':'Name 3','Description':'abc','Skills':[{Type:abc,Technical:abc,Description:abc}],'Status':false,'Inactive':1}]}

林克版本:


string content = Console.ReadLine();


var matchResult = new Regex("(?<='Skills':).*?}]").Matches(content);


var jsonWithNormalizedSkillField = matchResult.Cast<Match>().Select(s => content.Replace(s.Value, s.Value.Replace("'", string.Empty))).FirstOrDefault();


Console.WriteLine(jsonWithNormalizedSkillField);

Console.ReadLine();


查看完整回答
反对 回复 2023-08-20
  • 1 回答
  • 0 关注
  • 155 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信