本文目錄一覽:
- 1、jsonobject怎麼獲取json中某個值
- 2、JSON解析器json-c
- 3、C++ jsoncpp 輸出名稱和值
- 4、c#讀取json
- 5、如何獲取json數據裡面的所有的name
- 6、怎麼用C語言獲取JSON中的數據?
jsonobject怎麼獲取json中某個值
這樣:
public static void jsonToBean(String data) {
try {
JSONArray array = new JSONArray(data);//將json字元串轉成json數組
for (int i = 0; i array.length(); i++) {//循環json數組
JSONObject ob = (JSONObject) array.get(i);//得到json對象
String name= ob.getString(“name”);//name這裡是列名稱,獲取json對象中列名為name的值
System.out.print(name);//輸出name
} catch (JSONException e) {
}
}
擴展資料:
注意事項
java處理 json格式字元串 : 轉成 JSONArray 或 JSONObject 類型
1、如果是JSONArray ,格式: 最外層是 中括弧,表示數組
格式 : [{key:value},{key:value}… ]
[“str1″,”str2″,”str3”,…]
語法:JSONArray array = JSONArray.parseArray(strs)
註:strs 必須是json格式的字元串, 以”[ ]”中括弧開頭結尾. 否則會報錯.
2、如果是JSONObject ,格式: 最外層是大括弧,表示對象
格式:{key:value}
語法::JSONObject result = JSONArray.parseObject(strs );
JSON解析器json-c
JSON-C實現了一個引用計數對象模型,它允許您輕鬆地使用C語言來構建JSON對象,將它們輸出為JSON格式的字元串,並將JSON格式字元串解析回JSON對象的C語言表示形式。它的目標是符合 RFC 7159 標準。
使用automake的編譯過程如下:
使用cmake編譯的過程如下:
cmake可選的幾個編譯選項為:
要使用json-c,最簡單的方式是包含json.h頭文件即可,或者最好是下列更具體的頭文件之一:
詳細且全面的API介紹文檔:
JSON-C支持的JSON對象類型有7種:
下面系列函數用於創建一個JSON對象:
給JSON對象增加欄位(不會增加引用計數):
刪除json對象的指定欄位,被刪除的對象引用計數減去1,如果這個val沒有更多的所有者,這個key對應的val被free,否則這個val的引用保存在內存中:
增加一個元素到json數組的末尾,obj引用計數不會增加,增加欄位的方式更加緊湊;如果需要獲取val的引用,需要用json_object_get()來傳遞該對象:
替換json數組中的值:
json數組的排序,這裡需要自己寫排序函數:
獲取json對象的長度,依據欄位的數目:
獲取json對象的哈希表:
獲取對象的數組列表:
獲取json的類型:
獲取json數組對象的長度:
獲取json對象的bool值,int和double對象是0轉換為FALSE,否則返回TRUE;非0長度的字元串返回TRUE;其他對象非空的話,返回TRUE:
獲取json對象的長度,如果參數不是string類型的json,返回0:
按照索引獲取json數組的對象:
轉換json對象到c字元串格式:
獲取JSON中指定類型的數值:
將字元串轉換為json對象:
以下兩個函數配合使用,前者獲取該對象指針的所有權,引用計數加1,如果對象已經被釋放,返回NULL;後者引用計數減1,如果對象已經被釋放,返回1:
類型判斷:
json_util.h提供了有關文件讀寫操作的函數,這個文件的內容是json格式的:
C++ jsoncpp 輸出名稱和值
Json::Reader arrayReader;
Json::Value arrayValue;
arrayReader.parse(jsonData, arrayValue);
Json::Value::Members arrayMember = arrayValue.getMemberNames(); //ayyayMember是成員名稱的集合,即name,age;
for(Json::Value::Members::iterator iter = arrayMember.begin(); iter != arrayMember.end(); ++iter) //遍歷json成員
{
string member_name= *iter;
string value_str = arrayValue[member_name].asString();
coutmember_name”:”value_strendl;
}
c#讀取json
先聲明,以下兩個方法我一直用
肯定沒有問題
TXT讀取方法
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using System.IO;
namespace WindowsApplication1
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
this.rT1.Text = “”;
FileStream fs1 = new FileStream(“2.txt”, FileMode.Open);
StreamReader sr = new StreamReader(fs1);
string str1 = sr.ReadToEnd();
this.rT1.Text = str1;
sr.Close();
fs1.Close();
}
}
}
———————————————————————————-
以下是 json的 序列化和反序列化
.net3.5提供了json對象序列化與反序列化的類。位置在:System.Runtime.Serialization.Json空間下。其中如果要應用這個空間還必須添加對
System.ServiceModel
System.ServiceModel.Web
這兩個庫文件的引用。
參考實體類:Customer
public class Customer
{
public int Unid { get; set; }
public string CustomerName { get; set; }
}
DataContractJsonSerializer
將對象序列化為 JavaScript 對象表示法 (JSON),並將 JSON 數據反序列化為對象。無法繼承此類。
其中有個方法WriteObject,它的功能定義為:將對象序列化為 JavaScript 對象表示法 (JSON) 文檔
它有三個方法重載,其中一個為:
public override void WriteObject(Stream stream,Object graph)
它的功能描述這:將指定對象序列化為 JavaScript 對象表示法 (JSON) 數據,並將生成的 JSON 寫入流中
(一)序列化
public string ToJson(Customer customer)
{
DataContractJsonSerializer ds = new DataContractJsonSerializer(typeof(Customer));
MemoryStream ms=new MemoryStream();
ds.WriteObject(ms, customer);
string strReturn=Encoding.UTF8.GetString(ms.ToArray());
ms.Close();
return strReturn;
}
創建類實例,通過它的WriteObject方法來向流寫入序列化的對象,再把流寫入到字元串中。就可以得到JSON對象。
測試一下:
Customer cc = new Customer {Unid=1,CustomerName=”John” };
string strJson = ToJson(cc);
Console.WriteLine(strJson);
結果為:{“CustomerName”:”John”,”Unid”:1}
(二)反序列化
ReadObject方法,其描述為:反序列化 JSON(JavaScript 對象表示法)數據,並返回反序列化的對象。
它有很多重載,現在通過一種:
public override Object ReadObject(Stream stream)
它從流中得到反序列化的對象。
public object FromJson(string strJson)
{
DataContractJsonSerializer ds = new DataContractJsonSerializer(typeof(Customer));
MemoryStream ms = new MemoryStream(Encoding.UTF8.GetBytes(strJson));
return ds.ReadObject(ms);
}
測試:
string strJson=”{\”CustomerName\”:\”John\”,\”Unid\”:1}”;
Customer c=FromJson(strJson) as Customer;
Console.WriteLine(c.Unid+” “+c.CustomerName);
(三)通過泛型方法對兩者進行修改
為了適應多類型實例的序列化與反序列化,通過泛型方法來實現。
public string ToJsonT(T t)
{
DataContractJsonSerializer ds = new DataContractJsonSerializer(typeof(T));
MemoryStream ms = new MemoryStream();
ds.WriteObject(ms, t);
string strReturn = Encoding.UTF8.GetString(ms.ToArray());
ms.Close();
return strReturn;
}
public T FromJsonT(string strJson) where T:class
{
DataContractJsonSerializer ds = new DataContractJsonSerializer(typeof(T));
MemoryStream ms = new MemoryStream(Encoding.UTF8.GetBytes(strJson));
return ds.ReadObject(ms) as T;
}
•反序列化時通過泛型約束來指定類型T為類類型。
測試:
Customer cc = new Customer {Unid=1,CustomerName=”John” };
string strJsons = ToJsonCustomer(cc);
Console.WriteLine(strJsons);
string strJson=”{\”CustomerName\”:\”John\”,\”Unid\”:1}”;
Customer c = FromJsonCustomer(strJson);
Console.WriteLine(c.Unid+” “+c.CustomerName);
如何獲取json數據裡面的所有的name
var json = { contry:{ area:{ man:”12萬”, women:”10萬” } } };//方式一:使用eval解析 var obj = eval(json); alert(obj.constructor);alert(obj.contry.area.women); //方式二:使用Funtion函數 var strJSON = “{name:’json name’}”;//得到的…
怎麼用C語言獲取JSON中的數據?
用C語言獲取JSON中的數據的方法是使用 CJSON。
以下簡單介紹用CJSON的思路及實現:
1)創建json,從json中獲取數據。
#nclude stdio.h
#include “cJSON.h”
char * makeJson()
{
cJSON * pJsonRoot = NULL;
pJsonRoot = cJSON_CreateObject();
if(NULL == pJsonRoot)
{
//error happend here
return NULL;
}
cJSON_AddStringToObject(pJsonRoot, “hello”, “hello world”);
cJSON_AddNumberToObject(pJsonRoot, “number”, 10010);
cJSON_AddBoolToObject(pJsonRoot, “bool”, 1);
cJSON * pSubJson = NULL;
pSubJson = cJSON_CreateObject();
if(NULL == pSubJson)
{
// create object faild, exit
cJSON_Delete(pJsonRoot);
return NULL;
}
cJSON_AddStringToObject(pSubJson, “subjsonobj”, “a sub json string”);
cJSON_AddItemToObject(pJsonRoot, “subobj”, pSubJson);
char * p = cJSON_Print(pJsonRoot);
// else use :
// char * p = cJSON_PrintUnformatted(pJsonRoot);
if(NULL == p)
{
//convert json list to string faild, exit
//because sub json pSubJson han been add to pJsonRoot, so just delete pJsonRoot, if you also delete pSubJson, it will coredump, and error is : double free
cJSON_Delete(pJsonRoot);
return NULL;
}
//free(p);
cJSON_Delete(pJsonRoot);
return p;
}
void parseJson(char * pMsg)
{
if(NULL == pMsg)
{
return;
}
cJSON * pJson = cJSON_Parse(pMsg);
if(NULL == pJson)
{
// parse faild, return
return ;
}
// get string from json
cJSON * pSub = cJSON_GetObjectItem(pJson, “hello”);
if(NULL == pSub)
{
//get object named “hello” faild
}
printf(“obj_1 : %s\n”, pSub-valuestring);
// get number from json
pSub = cJSON_GetObjectItem(pJson, “number”);
if(NULL == pSub)
{
//get number from json faild
}
printf(“obj_2 : %d\n”, pSub-valueint);
// get bool from json
pSub = cJSON_GetObjectItem(pJson, “bool”);
if(NULL == pSub)
{
// get bool from json faild
}
printf(“obj_3 : %d\n”, pSub-valueint);
// get sub object
pSub = cJSON_GetObjectItem(pJson, “subobj”);
if(NULL == pSub)
{
// get sub object faild
}
cJSON * pSubSub = cJSON_GetObjectItem(pSub, “subjsonobj”);
if(NULL == pSubSub)
{
// get object from subject object faild
}
printf(“sub_obj_1 : %s\n”, pSubSub-valuestring);
cJSON_Delete(pJson);
}
int main()
{
char * p = makeJson();
if(NULL == p)
{
return 0;
}
printf(“%s\n”, p);
parseJson(p);
free(p);//這裡不要忘記釋放內存,cJSON_Print()函數或者cJSON_PrintUnformatted()產生的內存,使用free(char *)進行釋放
return 0;
}
2)創建json數組和解析json數組
//創建數組,數組值是另一個JSON的item,這裡使用數字作為演示
char * makeArray(int iSize)
{
cJSON * root = cJSON_CreateArray();
if(NULL == root)
{
printf(“create json array faild\n”);
return NULL;
}
int i = 0;
for(i = 0; i iSize; i++)
{
cJSON_AddNumberToObject(root, “hehe”, i);
}
char * out = cJSON_Print(root);
cJSON_Delete(root);
return out;
}
//解析剛剛的CJSON數組
void parseArray(char * pJson)
{
if(NULL == pJson)
{
return ;
}
cJSON * root = NULL;
if((root = cJSON_Parse(pJson)) == NULL)
{
return ;
}
int iSize = cJSON_GetArraySize(root);
for(int iCnt = 0; iCnt iSize; iCnt++)
{
cJSON * pSub = cJSON_GetArrayItem(root, iCnt);
if(NULL == pSub)
{
continue;
}
int iValue = pSub-valueint;
printf(“value[%2d] : [%d]\n”, iCnt, iValue);
}
cJSON_Delete(root);
return;
}
有兩種方法:
一是標準的輸出輸入方式 比如新建一個磁碟文件c:\a.txt, 將鍵盤輸入的一字元串寫到文件中:
FILE *ft;
char str[50];
ft=fopen(“c:\\a.txt”,”w+”);
printf(“輸入一個字元串:”);
scanf(“%s”,str);
fputs(str,ft);
fclose(ft);
//重新打開這個文件並讀出字元串,顯示在屏幕上 ft=fopen(“c:\\a.txt”,”rt”);
fgets(str,50,ft);
fclose(ft); printf(“%s”,str);
二是低級輸入輸出方式 仍如上例:
int hd; char str[50]; printf(“輸入一個字元串:”);
scanf(“%s”,str);
hd=open(“c:\\a.txt”,O_CREAT|O_TEXT|O_WRONLY);
write(hd,str,strlen(str));
close(hd); //重新打開這個文件並讀出字元串,顯示在屏幕上。
hd=open(“c:\\a.txt”,O_TEXT|O_RDONLY); read(hd,str,50);
close(hd); printf(“%s”,str)。
原創文章,作者:QVBE,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/133697.html