Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/260.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/.net/24.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
将CSV字符串反序列化为C#对象_C#_.net_Deserialization_Jira - Fatal编程技术网

将CSV字符串反序列化为C#对象

将CSV字符串反序列化为C#对象,c#,.net,deserialization,jira,C#,.net,Deserialization,Jira,我收到来自Jira API的响应,要求反序列化到数据模型中: com.atlassian.greenhopper.service.sprint.Sprint@40675167[id=10151,rapidViewId=171,state=CLOSED,name=Sprint 37.1,startDate=2015-07-30T16:00:22.000+03:00,endDate=2015-08-13T16:00:00.000+03:00,completeDate=2015-08-13T14:31

我收到来自Jira API的响应,要求反序列化到数据模型中:

com.atlassian.greenhopper.service.sprint.Sprint@40675167[id=10151,rapidViewId=171,state=CLOSED,name=Sprint 37.1,startDate=2015-07-30T16:00:22.000+03:00,endDate=2015-08-13T16:00:00.000+03:00,completeDate=2015-08-13T14:31:34.343+03:00,sequence=10151]
这实际上是当前sprint for issue的信息。 我需要将其反序列化为如下模型:

public class Model
{
    public string name { get; set; }
    ...
}
我已经删除了所有不需要的信息,比如
com.atlassian.greenhopper.service.sprint。Sprint@40675167
使用
Regex模式\[(.*?\])
所以我在里面有括号和所有内容

现在我完全停止了寻找将该字符串转换为数据模型的方法。

在Atlassian Answers页面上找到了以下内容,并且似乎没有该内部对象的JSON表示。如该线程的示例所示:

customfield_10007:[
"com.atlassian.greenhopper.service.sprint.Sprint@a29f07[rapidViewId=<null>,state=CLOSED,name=NORD - Sprint 42,startDate=2013-07-29T06:47:00.000+02:00,endDate=2013-08-11T20:47:00.000+02:00,completeDate=2013-08-14T15:31:33.157+02:00,id=107]",
"com.atlassian.greenhopper.service.sprint.Sprint@769133[rapidViewId=<null>,state=ACTIVE,name=NORD - Sprint 43,startDate=2013-08-14T15:32:47.322+02:00,endDate=2013-08-23T15:32:47.322+02:00,completeDate=<null>,id=117]"
],
以下是上述内容的输出:


它是否应该以Json格式向您提供响应数据?反序列化很简单。因为我已经尝试了所有方法,即使替换符号也会以Json格式显示响应。使用Json反序列化程序,您就完成了。尝试一下.NET SDK-@adricadar,您认为拆分是最好的方法吗?没有其他选择吗?
   public class DataObject
    {
        public string id { get; set; }
        public string rapidViewId { get; set; }
        public string state { get; set; } 
        public string name { get; set; }
        public string startDate { get; set; }
        public string endDate { get; set; }
        public string completeDate { get; set; }
        public string sequence { get; set; }
    }


    public class Program
    {
        private const string sampleStringData =
            @"[id=10151,rapidViewId=171,state=CLOSED,name=Sprint 37.1,startDate=2015-07-30T16:00:22.000+03:00,endDate=2015-08-13T16:00:00.000+03:00,completeDate=2015-08-13T14:31:34.343+03:00,sequence=10151]";


        static void Main(string[] args)
        {
            var dataObject = new DataObject();

            string[][] splitted;
            var sampleWithNoBrackets = sampleStringData.Substring(1,sampleStringData.Length-2);
            splitted = sampleWithNoBrackets.Split(',').Select(p => p.Split('=')).ToArray();

            dataObject.id           = splitted[0][1];
            dataObject.rapidViewId  = splitted[1][1];
            dataObject.state        = splitted[2][1];
            dataObject.name         = splitted[3][1];
            dataObject.startDate    = splitted[4][1];
            dataObject.endDate      = splitted[5][1];
            dataObject.completeDate = splitted[6][1];
            dataObject.sequence     = splitted[7][1];

            Console.ReadKey();
        }
    }