標籤:
近期又做了個問卷調查,問卷調查一次性要儲存一二十個題目和答案!所以嘞,博主為了偷懶,就直接把答卷內容儲存成了Json格式!
好處當然是很多啦! 只需一個欄位就能儲存整個答卷的內容! 想想都刺激!哈哈~!
好了,閑話少敘,直入正題!
首先,一般不會儲存題目,要求的可能是只儲存答案!比如第幾題對應的調查者選的是什麼答案等等!
先聲明一個題目類Expreience,當然,你如果想連題目一起加上的話,你可以多聲明幾個欄位嘛,是吧!
代碼如下:
public class Expreience { public string exp1 { get; set; } public string exp2 { get; set; } public string exp3 { get; set; } public string exp4 { get; set; } public string exp5 { get; set; } public string exp6 { get; set; } public string exp7 { get; set; } public string exp8 { get; set; } public string exp9 { get; set; } public string exp10 { get; set; } }
歐克,現在我有十道題,從上面的代碼就能看粗來!廢話連篇,滿臉嫌棄,哼哼哼~!
好吧,精神分裂患者!
聲明好了題目類,接下來該把字串改成Json格式了,注意哈!!!不要走神!
你快點兒吧,囉嗦!
好吧,現在來看下轉化代碼:
Hashtable hash = new Hashtable();hash["exp1"] = "選A"; hash["exp2"] = "選博主";hash["exp3"] = "回去好好養著";hash["exp4"] = "小白";hash["exp5"] = "去撿過來";hash["exp6"] = "小白";hash["exp7"] = "去給粑粑的鞋叼過來";hash["exp8"] = "小白";hash["exp9"] = "賞你根骨頭";hash["exp10"] = "WangWang旺";JavaScriptSerializer ser = new JavaScriptSerializer();
string ansJsonStr = ser.Serialize(hash);
聲明Hashtable類,以索引值對的形式儲存每道題對應的值,然後轉換成Json字串;切記:hash["exp1"]中的exp1要和題目類Expreience中的exp1對應起來!
記得引用:
using System.Web.Script.Serialization;using System.Collections;
好了,就這麼簡單,看看轉換後的格式:
{ "exp4": "小白", "exp9": "賞你根骨頭", "exp6": "小白", "exp1": "選A", "exp3": "回去好好養著", "exp8": "小白", "exp5": "去撿過來", "exp10": "WangWang旺", "exp7": "去給粑粑的鞋叼過來", "exp2": "選博主"}
呃呃呃。。。雖是沒按順序轉換,但絕對是正確滴! 好尷尬呀!!!這破機器~!呵呵呵...
好了,來看下資料庫儲存的狀況:
好神奇喲,真是一個欄位儲存的啊!讓你裝逼,看看你怎麼取值,哼哼~!
取值?哎呀,我好怕呀!難倒我了喲!!!哈哈哈,逗你玩兒!
歐克,現在來說說,如何將這段字串再轉化成可以隨意取值的類型,方便我們取任何一道題的值!
能裝進去,肯定就能釋放粗來呀!你看著吧!哈哈~
少囉嗦,快點兒!不講的話,尿點兒就來了!
好好好,閑言少敘,Go On!!!
轉換回來其實也很簡單的,上代碼:
public Expreience GetData(string jsonStr) { return (Expreience)Newtonsoft.Json.JsonConvert.DeserializeObject(jsonStr, typeof(Expreience)); }
好了,轉換好了! 什嗎?怎麼用?這都不會,真是夠笨的!好吧,繼續》》》
public string GetDataToString(string jsonStr) { if (string.IsNullOrEmpty(jsonStr)) return ""; Expreience strtemp = GetData(jsonStr); string dataTemp = "第1題:" + strtemp.exp1 + "第2題:" + strtemp.exp2 + "第3題:" + strtemp.exp3 + "第4題:" + strtemp.exp4 + "第5題:" + strtemp.exp5 + "第6題:" + strtemp.exp6 + "第7題:" + strtemp.exp7 + "第8題:" + strtemp.exp8 + "第9題:" + strtemp.exp9; return dataTemp; }
好了,按順序取值了!
就這麼簡單!嗯嗯嗯!
拙文一篇,忘各位賜教!
討論群: 225443677 歡迎騷擾,不警示的,也不會懷孕的!真的,加了的人都知道!
謝謝!
.net 字串和JSON格式的互換