• C# string.Format json格式字符串报错”输入字符串的格式不正确“


    当我们在string.Format中传入Json字符串时,会报”输入字符串的格式不正确“,这是因为json的"{"符号的问题,最开始我是想着用转义一下"{",但是转义后我发现原来的非json占位格式缺报错了,因为我破坏了它的占位格式

    问题还是没有解决,但是最终从另一个角度解决了我的需求,那就是从把string.Format封装起来,在内部进行判断,如果它的orgs的length为0,那么我们就直接输出format,否则才调用string.Format,一般情况下我们不会在json字符串中使用占位符,所以,要么我们直接传入json字符串,要么把json作为orgs的一个传进去,这样基本就避免了报错了,看代码

      

        class Program {
            static void Main(string[] args) {
                try {
                    string str1 = "{"aaa":"123","bbb":{"ccc":"456"}}";
                    //Console.WriteLine(string.Format(str1));   //直接将json传入string.Format中会报错,因为json中的{}和string.Format的占位符冲突了
                    Console.WriteLine(Format(str1));  //封装一下,直接传入json就不会报错了
                    Console.WriteLine(Format("ct:{0},rs:123", str1));  //将json作为一个org传入也不会报错
                    //Console.WriteLine(Format("{"ct":"{0}","rs":123}",123));  //当然如果在json中使用占位符,依然会报错,然而一般情况下咱们也不会这么用
    
                } catch (Exception ex) {
                    Console.WriteLine(ex.ToString());
                }
                Console.ReadKey();
            }
            private static string Format(string msg, params object[] ps) {
                if (ps.Length > 0) {
                    msg = string.Format(msg, ps);
                }
                return msg;
            }
        }
  • 相关阅读:
    如何在百度文库里面免费下载东西
    CompareTo
    MySql常用日期函数(转载)
    Oracle之ORDER BY
    Spring之Ioc
    在使用与测绘有关软件中的困难
    HDOJ_1008_Elevator
    HDOJ_1005_Number Sequence
    HDOJ_1004_Let the Balloon Rise
    HDOJ_1003_MaxSum
  • 原文地址:https://www.cnblogs.com/luludongxu/p/10653436.html
Copyright © 2020-2023  润新知