1)解析为 JObject
private void ParseJson() { // 解析为JObject
string jsonStr = "{'name': 'zhangsan', 'sex': 'male', 'age': 23}";
JObject jo = JsonConvert.DeserializeObject<JObject>(jsonStr);
print("name=" + jo["name"] + ", sex=" + jo["sex"] + ", age=" + jo["age"]);
}
说明:需要使用以下命名空间:
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
2)解析为 Dictionary
private void ParseJson() { // 解析为Dictionary<string, object>
string jsonStr = "{'name': 'zhangsan', 'sex': 'male', 'age': 23}";
Dictionary<string, object> dict = JsonConvert.DeserializeObject<Dictionary<string, object>>(jsonStr);
print("name=" + dict["name"] + ", sex=" + dict["sex"] + ", age=" + dict["age"]);
}
3)解析为封装类
class Student {
public string name;
public string sex;
public int age;
public override string ToString() {
return "{name: " + name + ", sex: " + sex + ", age: " + age + "}";
}
}
private void ParseJson() { // 解析为Student
string jsonStr = "{'name': 'zhangsan', 'sex': 'male', 'age': 23}";
Student stu = JsonConvert.DeserializeObject<Student>(jsonStr);
print("stu=" + stu);
}
1)解析为 JArray
private void ParseJson() { // 解析一维数组(JArray)
string jsonStr = "[1, 2, 3, 4, 5]";
JArray ja = JsonConvert.DeserializeObject<JArray>(jsonStr);
print(GetJArrayString(ja));
}
private string GetJArrayString(JArray ja) {
string str = "[";
if (ja != null && ja.Count > 0) {
str += ja[0];
}
for (int i = 1; i < ja.Count; i++) {
str += ", " + ja[i];
}
return str + "]";
}
2)解析为数组
private void ParseJson() { // 解析一维数组(int[])
string jsonStr = "[1, 2, 3, 4, 5]";
int[] arr = JsonConvert.DeserializeObject<int[]>(jsonStr);
print(GetArrString(arr));
}
private string GetArrString(int[] arr) {
string str = "[";
if (arr != null && arr.Length > 0) {
str += arr[0];
}
for (int i = 1; i < arr.Length; i++) {
str += ", " + arr[i];
}
return str + "]";
}
3)解析为列表
private void ParseJson() { // 解析一维数组(List<int>)
string jsonStr = "[1, 2, 3, 4, 5]";
List<int> list = JsonConvert.DeserializeObject<List<int>>(jsonStr);
print(GetListString(list));
}
private string GetListString(List<int> list) {
string str = "[";
if (list != null && list.Count > 0) {
str += list[0];
}
for (int i = 1; i < list.Count; i++) {
str += ", " + list[i];
}
return str + "]";
}
1)解析为 JArray
private void ParseJson() { // 解析二维数组(JArray)
string jsonStr = "[[1, 2], [3, 4], [5, 6]]";
JArray ja2 = JsonConvert.DeserializeObject<JArray>(jsonStr);
print(GetJArrayString2(ja2));
}
private string GetJArrayString2(JArray ja2) {
string str = "[";
if (ja2 != null && ja2.Count > 0) {
str += GetJArrayString((JArray)ja2[0]);
}
for (int i = 1; i < ja2.Count; i++) {
str += ", " + GetJArrayString((JArray)ja2[i]);
}
return str + "]";
}
说明:GetJArrayString 方法见 2 1)节。
2)解析为二维数组
private void ParseJson() { // 解析二维数组(int[][])
string jsonStr = "[[1, 2], [3, 4], [5, 6]]";
int[][] arr = JsonConvert.DeserializeObject<int[][]>(jsonStr);
print(GetArrString2(arr));
}
private string GetArrString2(int[][] arr) {
string str = "[";
if (arr != null && arr.Length > 0) {
str += GetArrString(arr[0]);
}
for (int i = 1; i < arr.Length; i++) {
str += ", " + GetArrString(arr[i]);
}
return str + "]";
}
说明:GetArrString 方法见 2 2)节。
1)解析为 JObject-JArray
private void ParseJson() { // "数组字典"混合解析(JObject-JArray)
string jsonStr = "{'vec1': [1, 2, 3, 4], 'vec2': [[1, 2], [3, 4], [5, 6]]}";
JObject jo = JsonConvert.DeserializeObject<JObject>(jsonStr);
print("vec1=" + GetJArrayString((JArray) jo["vec1"]) + ", vec2=" + GetJArrayString2((JArray) jo["vec2"]));
}
说明: GetJArrayString 方法见 2 1)节,GetJArrayString2 方法见 3 1)节。
2)解析为封装类
class VecInfo {
public int[] vec1;
public int[][] vec2;
}
private void ParseJson() { // "数组字典"混合解析(封装类)
string jsonStr = "{'vec1': [1, 2, 3, 4], 'vec2': [[1, 2], [3, 4], [5, 6]]}";
VecInfo vecInfo = JsonConvert.DeserializeObject<VecInfo>(jsonStr);
print("vec1=" + GetArrString(vecInfo.vec1) + ", vec2=" + GetArrString2(vecInfo.vec2));
}
说明: GetArrString 方法见 2 2)节,GetArrString2 方法见 3 2)节。
1)解析为 JArray-JObject
private void ParseJson() { // "字典数组"混合解析(JArray-JObject)
string jsonStr = "[{'name': 'xiaomin', 'sex': 'male', 'age': 23}, {'name': 'xiaohong', 'sex': 'female', 'age': 21}]";
JArray ja = JsonConvert.DeserializeObject<JArray>(jsonStr);
string str = "[";
if (ja.Count > 0) {
str += "{name: " + ja[0]["name"] + ", sex: " + ja[0]["sex"] + ", age: " + ja[0]["age"] + "}";
}
for (int i = 1; i < ja.Count; i++) {
str += ", {name: " + ja[i]["name"] + ", sex: " + ja[i]["sex"] + ", age: " + ja[i]["age"] + "}";
}
str += "]";
print(str);
}
2)解析为数组封装类
private void ParseJson() { // "字典数组"混合解析(Student[])
string jsonStr = "[{'name': 'xiaomin', 'sex': 'male', 'age': 23}, {'name': 'xiaohong', 'sex': 'female', 'age': 21}]";
Student[] stus = JsonConvert.DeserializeObject<Student[]>(jsonStr);
print(GetStudentArrString(stus));
}
private string GetStudentArrString(Student[] stus) {
string str = "[";
if (stus != null && stus.Length > 0) {
str += stus[0];
}
for (int i = 1; i < stus.Length; i++) {
str += ", " + stus[i];
}
return str + "]";
}
说明:Student 类见 1 3)节。
3)解析为列表封装类
private void ParseJson() { // "字典数组"混合解析(List<Student>)
string jsonStr = "[{'name': 'xiaomin', 'sex': 'male', 'age': 23}, {'name': 'xiaohong', 'sex': 'female', 'age': 21}]";
List<Student> list = JsonConvert.DeserializeObject<List<Student>>(jsonStr);
print(GetStudentListString(list));
}
private string GetStudentListString(List<Student> list) {
string str = "[";
if (list != null && list.Count > 0) {
str += list[0];
}
for (int i = 1; i < list.Count; i++) {
str += ", " + list[i];
}
return str + "]";
}
1)字典格式点
private void ParseJson() {
string jsonStr = "[{'x': 1, 'y': 2, 'z': 3}, {'x': 4, 'y': 5, 'z': 6}, {'x': 7, 'y': 8, 'z': 9}]";
Vector3[] points = JsonConvert.DeserializeObject<Vector3[]>(jsonStr);
print(GetVectorString(points));
}
private string GetVectorString(Vector3[] points) {
string str = "[";
if (points != null && points.Length > 0) {
str += points[0];
}
for (int i = 1; i < points.Length; i++) {
str += ", " + points[i];
}
return str + "]";
}
2)数组格式点
private void ParseJson() {
string jsonStr = "[[1, 2, 3], [4, 5, 6], [7, 8, 9]]";
float[][] arr = JsonConvert.DeserializeObject<float[][]>(jsonStr);
Vector3[] points = new Vector3[arr.Length];
for(int i = 0; i < arr.Length; i++) {
points[i] = new Vector3(arr[i][0], arr[i][1], arr[i][2]);
}
print(GetVectorString(points));
}
说明:GetVectorString 方法同第 1)节。
private void ParseJson() { // 解析为JObject
string jsonStr = File.ReadAllText("Assets/Scenes/Student.json", Encoding.UTF8);
JObject jo = JsonConvert.DeserializeObject<JObject>(jsonStr);
print("name=" + jo["name"] + ", sex=" + jo["sex"] + ", age=" + jo["age"]);
}
说明:File 和 Encoding.UTF8 需要引入命名空间 System.IO、System.Text。
Student.json
{'name': 'zhangsan', 'sex': 'male', 'age': 23} 我有一个字符串input="maybe(thisis|thatwas)some((nice|ugly)(day|night)|(strange(weather|time)))"Ruby中解析该字符串的最佳方法是什么?我的意思是脚本应该能够像这样构建句子:maybethisissomeuglynightmaybethatwassomenicenightmaybethiswassomestrangetime等等,你明白了......我应该一个字符一个字符地读取字符串并构建一个带有堆栈的状态机来存储括号值以供以后计算,还是有更好的方法?也许为此目的准备了一个开箱即用的库?
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
我正在使用ruby1.9解析以下带有MacRoman字符的csv文件#encoding:ISO-8859-1#csv_parse.csvName,main-dialogue"Marceu","Giveittohimóhe,hiswife."我做了以下解析。require'csv'input_string=File.read("../csv_parse.rb").force_encoding("ISO-8859-1").encode("UTF-8")#=>"Name,main-dialogue\r\n\"Marceu\",\"Giveittohim\x97he,hiswife.\"\
在我的Controller中,我通过以下方式在我的index方法中支持HTML和JSON:respond_todo|format|format.htmlformat.json{renderjson:@user}end在浏览器中拉起它时,它会自然地以HTML呈现。但是,当我对/user资源进行内容类型为application/json的curl调用时(因为它是索引方法),我仍然将HTML作为响应。如何获取JSON作为响应?我还需要说明什么? 最佳答案 您应该将.json附加到请求的url,提供的格式在routes.rb的路径中定义。这
有时我需要处理键/值数据。我不喜欢使用数组,因为它们在大小上没有限制(很容易不小心添加超过2个项目,而且您最终需要稍后验证大小)。此外,0和1的索引变成了魔数(MagicNumber),并且在传达含义方面做得很差(“当我说0时,我的意思是head...”)。散列也不合适,因为可能会不小心添加额外的条目。我写了下面的类来解决这个问题:classPairattr_accessor:head,:taildefinitialize(h,t)@head,@tail=h,tendend它工作得很好并且解决了问题,但我很想知道:Ruby标准库是否已经带有这样一个类? 最佳
如何在ruby中调用C#dll? 最佳答案 我能想到几种可能性:为您的DLL编写(或找人编写)一个COM包装器,如果它还没有,则使用Ruby的WIN32OLE库来调用它;看看RubyCLR,其中一位作者是JohnLam,他继续在Microsoft从事IronRuby方面的工作。(估计不会再维护了,可能不支持.Net2.0以上的版本);正如其他地方已经提到的,看看使用IronRuby,如果这是您的技术选择。有一个主题是here.请注意,最后一篇文章实际上来自JohnLam(看起来像是2009年3月),他似乎很自在地断言RubyCL
我正在尝试在Ruby中复制Convert.ToBase64String()行为。这是我的C#代码:varsha1=newSHA1CryptoServiceProvider();varpasswordBytes=Encoding.UTF8.GetBytes("password");varpasswordHash=sha1.ComputeHash(passwordBytes);returnConvert.ToBase64String(passwordHash);//returns"W6ph5Mm5Pz8GgiULbPgzG37mj9g="当我在Ruby中尝试同样的事情时,我得到了相同sha
简而言之错误:NOTE:Gem::SourceIndex#add_specisdeprecated,useSpecification.add_spec.Itwillberemovedonorafter2011-11-01.Gem::SourceIndex#add_speccalledfrom/opt/local/lib/ruby/site_ruby/1.8/rubygems/source_index.rb:91./opt/local/lib/ruby/gems/1.8/gems/rails-2.3.8/lib/rails/gem_dependency.rb:275:in`==':und
我有一个非常简单的RubyRack服务器,例如:app=Proc.newdo|env|req=Rack::Request.new(env).paramspreq.inspect[200,{'Content-Type'=>'text/plain'},['Somebody']]endRack::Handler::Thin.run(app,:Port=>4001,:threaded=>true)每当我使用JSON对象向服务器发送POSTHTTP请求时:{"session":{"accountId":String,"callId":String,"from":Object,"headers":
我正在尝试使用Curbgem执行以下POST以解析云curl-XPOST\-H"X-Parse-Application-Id:PARSE_APP_ID"\-H"X-Parse-REST-API-Key:PARSE_API_KEY"\-H"Content-Type:image/jpeg"\--data-binary'@myPicture.jpg'\https://api.parse.com/1/files/pic.jpg用这个:curl=Curl::Easy.new("https://api.parse.com/1/files/lion.jpg")curl.multipart_form_