как переписать переменую Json ?

lzlmrf

Client
Регистрация
14.08.2015
Сообщения
487
Благодарностей
148
Баллы
43
как переписать переменую Json ? кубика нет для переназначения а присваивание снипетом не работает.
 

Nick

Client
Регистрация
22.07.2014
Сообщения
1 963
Благодарностей
796
Баллы
113
Json это не переменная, а формат данных. Видел в одной статье, как подключали библиотечку для работы с json, встроенного такого функционала не припомню.

Что именно не работает? Приложите проект, сниппет, скриншот хоть какой-то...
 

ol1ver

Client
Регистрация
29.08.2013
Сообщения
332
Благодарностей
82
Баллы
28

Nick

Client
Регистрация
22.07.2014
Сообщения
1 963
Благодарностей
796
Баллы
113
Код:
//вернуть строку, разделённую точкой с запятой

var tmp = project.Variables["tmp"].Value;
var fields = "uid,name,description,shortname,picAvatar,members_count,shop_visible_public".Split(',');

var regex = new Regex("\"([^\"]+)\":\"?(.*?)\"?(,|}|\\])");
var d = regex.Matches(tmp).Cast<Match>().ToDictionary(k=>k.Groups[1].Value, v=>v.Groups[2].Value);
return string.Join(";", fields.Select(f=>(d.Keys.Contains(f))?d[f]:""));

http://zennolab.com/discussion/threads/json-i-c.16858/#post-105530

//from json to table
string json = project.Variables["json"].Value;
var table =  project.Tables["table"];
List<string> id_list = System.Text.RegularExpressions.Regex.Matches(json, "(?<=id\":\").*?(?=\")").Cast<System.Text.RegularExpressions.Match>().Select(v=>v.Value).ToList<string>();
List<string> text_list = System.Text.RegularExpressions.Regex.Matches(json, "(?<=text\":\").*?(?=\")").Cast<System.Text.RegularExpressions.Match>().Select(v=>v.Value).ToList<string>();
lock(SyncObjects.TableSyncer){
    for(int i=0; i<id_list.Count; i++)
        table.AddRow(new List<string> {id_list, text_list});
}

//from json to table
string json = project.Variables["json"].Value;
var table =  project.Tables["table"];
var json_serializer = new System.Web.Script.Serialization.JavaScriptSerializer();
Dictionary<string,object> mes = json_serializer.Deserialize<Dictionary<string,object>>(json);
var list = (System.Collections.ArrayList)mes["mes"];
lock(SyncObjects.TableSyncer){
    foreach (var item in list){
        string id = (string)((Dictionary<string, object>)(item))["id"];
        string text = (string)((Dictionary<string, object>)(item))["text"];
        table.AddRow(new List<string> {id, text});
    }
}

//http://zennolab.com/discussion/threads/reguljarka-v-snipete.20636/#post-136117
//from json to table - many columns
var tmp = project.Variables["tmp"].Value;
var fields = "uid,name,description,shortname,picAvatar,members_count,shop_visible_public".Split(',');

var regex = new Regex("\"([^\"]+)\":\"?(.*?)\"?(,|}|\\])");
var d = regex.Matches(tmp).Cast<Match>().ToDictionary(k=>k.Groups[1].Value, v=>v.Groups[2].Value);
return string.Join(";", fields.Select(f=>(d.Keys.Contains(f))?d[f]:""));
 

Кто просматривает тему: (Всего: 1, Пользователи: 0, Гости: 1)