1. 程式人生 > >requests json與字典物件互相轉換

requests json與字典物件互相轉換

轉自:https://www.cnblogs.com/Lin-Yi/p/7640147.html、http://www.jb51.net/article/73450.htm

import requests
import json
'''
json.loads(json_str) json字串轉換成字典
json.dumps(dict) 字典轉換成json字串 
'''
# 這是一個ajax發起的get請求,獲取一個json物件
r = requests.get("https://m.douban.com/rexxar/api/v2/subject_collection/movie_showing/items?os=ios&for_mobile=1&start=0&count=18&loc_id=108288&_=0")
json_response = r.content.decode()  # 獲取r的文字 就是一個json字串

# 將json字串轉換成dic字典物件
dict_json = json.loads(json_response)
print(type(dict_json))

# 將字典轉換成json字串
str_json = json.dumps( dict_json )
print(type(str_json))

# 字典轉換成json 存入本地檔案
with open('./a.txt','w') as f:
# 設定不轉換成ascii  json字串首縮排
   f.write( json.dumps( dict_json,ensure_ascii=False,indent=2 ) )

Python的json模組提供了一種很簡單的方式來編碼和解碼JSON資料。 其中兩個主要的函式是 json.dumps() 和 json.loads() , 要比其他序列化函式庫如pickle的介面少得多。 下面演示如何將一個Python資料結構轉換為JSON:

import json
 
data = {
'name' : 'ACME',
'shares' : 100,
'price' : 542.23
}
 
json_str = json.dumps(data)
下面演示如何將一個JSON編碼的字串轉換回一個Python資料結構:
data = json.loads(json_str)

如果你要處理的是檔案而不是字串,你可以使用 json.dump() 和 json.load() 來編碼和解碼JSON資料。例如:

# Writing JSON data
with open('data.json', 'w') as f:
 json.dump(data, f)
 
# Reading data back
with open('data.json', 'r') as f:
 data = json.load(f)
用法示例:
相對於python解析XML來說,我還是比較喜歡json的格式返回,現在一般的api返回都會有json與XML格式的選擇,json的解析起來個人覺得相對簡單些
先看一個簡單的豆瓣的圖書查詢的api返回
http://api.douban.com/v2/book/isbn/9787218087351
{
rating: {
 max: 10,
 numRaters: 79,
 average: "9.1",
 min: 0
},
subtitle: "",
author: [
 "野夫"
],
pubdate: "2013-9",
tags: [
 {
 count: 313,
 name: "野夫",
 title: "野夫"
 },
 {
 count: 151,
 name: "散文隨筆",
 title: "散文隨筆"
 },
 {
 count: 83,
 name: "身邊的江湖",
 title: "身邊的江湖"
 },
 {
 count: 82,
 name: "土家野夫",
 title: "土家野夫"
 },
 {
 count: 70,
 name: "散文",
 title: "散文"
 },
 {
 count: 44,
 name: "中國文學",
 title: "中國文學"
 },
 {
 count: 43,
 name: "隨筆",
 title: "隨筆"
 },
 {
 count: 38,
 name: "中國現當代文學",
 title: "中國現當代文學"
 }
],
origin_title: "",
image: "http://img5.douban.com/mpic/s27008269.jpg",
binding: "",
translator: [ ],
catalog: "自序 讓記憶抵抗 001 掌瓢黎爺 024 遺民老譚 039 亂世遊擊:表哥的故事 058 綁赴刑場的青春 076 風住塵香花已盡 083 “酷客”李斯 100 散材毛喻原 113 頹世華筵憶黃門 122 球球外傳: 一個時代和一隻小狗的際遇 141 童年的恐懼與仇恨 151 殘忍教育 167 湖山一夢繫平生 174 香格里拉散記 208 民國屐痕",
pages: "256",
images: {
 small: "http://img5.douban.com/spic/s27008269.jpg",
 large: "http://img5.douban.com/lpic/s27008269.jpg",
 medium: "http://img5.douban.com/mpic/s27008269.jpg"
},
alt: "http://book.douban.com/subject/25639223/",
id: "25639223",
publisher: "廣東人民出版社",
isbn10: "7218087353",
isbn13: "9787218087351",
title: "身邊的江湖",
url: "http://api.douban.com/v2/book/25639223",
alt_title: "",
author_intro: "鄭世平,筆名野夫,網名土家野夫。畢業於武漢大學,曾當過警察、囚徒、書商。曾出版歷史小說《父親的戰爭》、散文集《江上的母親》(獲臺北2010國際書展非虛構類圖書大獎,是該獎項第一個大陸得主)、散文集《鄉關何處》(被新浪網、鳳凰網、新華網分別評為2012年年度好書)。",
summary: "1.野夫書稿中被刪減最少,最能體現作者觀點、情感的作品。 2.文字凝練,具有極強的感染力。以一枝孤筆書寫那些就在你我身邊的大歷史背景下普通人的生活變遷。 3. 柴靜口中“一半像警察,一半像土匪”的野夫,以其特有的韻律表達世間的歡笑和悲苦。",
price: "32元"
}

下面我們通過python來取出想要的資訊,比如我們想要rating,images裡的large和summary

import urllib2
import json
 
html = urllib2.urlopen(r'http://api.douban.com/v2/book/isbn/9787218087351')
 
hjson = json.loads(heml.read())
 
print hjson['rating']
print hjson['images']['large']
print hjson['summary']