国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

Python 如何保存json文件并格式化

瀏覽:18日期:2022-06-21 13:54:35
背景

最近自己搞些小東西,需要用json文件存儲些文件屬性什么的,但是發現用json包里的json.dump()方法存json文件的效果好丑……(其實是沒仔細看方法), 于是上網找了一份格式化json文件的代碼,效果挺不錯,用了遞歸的思想,學習了一波并找到了其中一點小bug。然后,發現其實json.dump()方法其實只需要設置一個參數就達到格式化的效果了……

下面介紹一下json.dump()和我修改后的那份代碼,附原github地址。

json.dump()

直接把常用參數列一下好了

參數名 解釋 obj 要存入json文件的python對象 fp 文件句柄 ensure_ascii 設置為False的話才可以把中文以中文的形式存到文件里,否則會是’xXXxXX’這種 indent 縮進的空格數,設置為非零值時,就起到了格式化的效果,比較美觀

也就是說在使用json.dump()的時候設置一下indent參數的值就好了。比如json.dump(json_dict, f, indent=4),加與不加的區別如下:

{'title_pinyin':'gywxw','title':'隔云勿相望','url':'http://www.ty2016.net/book/gywxw/','description':'大學剛畢業,她嫁給了林安森可是結婚三年,電視上常看到他出席各種場合攜女相伴,她卻再沒再親眼見過他。'}

{ 'title_pinyin':'gywxw', 'title':'隔云勿相望', 'url':'http://www.ty2016.net/book/gywxw/', 'description':'大學剛畢業,她嫁給了林安森可是結婚三年,電視上常看到他出席各種場合攜女相伴,她卻再沒再親眼見過他。'}遞歸實現

直接粘過來了,不難理解,效果跟上邊是一樣的。

# -*- encoding: utf-8 -*-class JsonFormatter: def __init__(self, intend=4, name='', encoding='utf-8'):’’’intend: 縮進空格數name: 文件名encoding: 文件編碼’’’self.name = nameself.intend = intendself.encoding = encodingself.stack = []self.obj = Noneself.source = self.get_source(name, self.encoding)self.prepare() @staticmethod def json_str(s):’’’給字符串套上雙引號’’’return ’'’ + s + ’'’ @staticmethod def get_source(name, encoding='utf-8'):with open(name, ’r’, encoding=encoding) as f: # 當不給split函數傳遞任何參數時,分隔符sep會采用任意形式的空白字符:空格、tab、換行、回車以及換頁符 return ’’.join(f.read().split()) def prepare(self):try: # python對象和json格式還是略有不同 self.source = self.source.replace('null', 'None').replace('true', 'True').replace('false', 'False') self.obj = eval(self.source)except: # json string 一定滿足python dict和list的組合 raise Exception(’Invalid json string!’) def line_intend(self, level=0):return ’n’ + ’ ’ * self.intend * level def parse_dict(self,obj=None,intend_level=0):if intend_level == 0: # 這個判斷是為了防止文件開頭出現空行 self.stack.append(’{’)else: self.stack.append(self.line_intend(intend_level)+’{’)intend_level += 1i = 0for key, value in obj.items(): key = self.json_str(str(key)) self.stack.append(self.line_intend(intend_level)+key+’:’) self.parse(value, intend_level) if i != len(obj.items())-1:# 這個處理是為了防止最后一對kv后面還有個逗號,這樣會造成json.load()函數無法讀取self.stack.append(’,’) i += 1self.stack.append(self.line_intend(intend_level-1)+’}’) def parse_list(self, obj=None, intend_level=0):if intend_level == 0: self.stack.append(’[’)else: self.stack.append(self.line_intend(intend_level)+’[’)intend_level += 1for i, item in zip(range(0, len(obj)), obj): self.parse(item, intend_level) if i != len(obj)-1:self.stack.append(’,’)self.stack.append(self.line_intend(intend_level-1)+’]’) def parse(self, obj, intend_level=0):if obj is None: self.stack.append(’null’)elif obj is True: self.stack.append(’true’)elif obj is False: self.stack.append(’false’)elif isinstance(obj, (int, float)): self.stack.append(str(obj))elif isinstance(obj, str): self.stack.append(self.json_str(obj))elif isinstance(obj, (list, tuple)): self.parse_list(obj, intend_level)elif isinstance(obj, dict): self.parse_dict(obj, intend_level)else: raise Exception(’Invalid json type %s!’ % obj) def render(self):self.parse(self.obj, 0)res_file = self.nameres = ’’.join(self.stack)with open(res_file, ’w’, encoding=self.encoding) as f: f.write(res)if __name__ == '__main__': jf = JsonFormatter(name='json.txt') jf.render()后記

以后碰見問題不能這樣焦躁了,先靜下心來看看API吧,說不定答案就在里面。

補充:python如何將數據保存到本地json文件

之前做了dict字典的合并,這一篇會將dict數據轉換成json格式的數據保存在本地,并在需要的時候讀取顯示。

將數據保存成.json文件:

@app.route(’/’, methods=[’GET’, ’POST’])def detail(): one = {’name’: ’xiaozhi’, ’age’: 188} mess1 = [’sss is sss’, ’aaa aa aaaa’] two = {'mess1': mess1} data = dict(one, **two) jsonData = json.dumps(data) fileObject = open(’data.json’, ’w’) fileObject.write(jsonData) fileObject.close() return jsonify({'success': 200, 'data': data})

在瀏覽器輸入URL后,json文件在本地創建,打開我們可以看到數據已經成功保存:

Python 如何保存json文件并格式化

讀取本地.json文件并解析顯示:

Python 如何保存json文件并格式化

如圖,我們做一個點擊事件,點擊按鈕讀取.json文件,并將信息顯示到對應的位置上

路由代碼:

@app.route(’/history’, methods=[’GET’, ’POST’])def history(): data = json.loads(request.form.get(’data’)) number = data[’number’] print(number) if number == ’01’:file = ’data.json’fb = open(file, ’r’)dicts = json.load(fb)fb.close()myjson = json.dumps(dicts)return myjson return ’no history’前臺頁面展示交互展示代碼:

<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title>test</title> <script src='http://www.cgvv.com.cn/bcjs/{{ url_for(’static’, filename=’js/jquery-1.7.1.min.js’) }}'></script></head><body> <input type='button' value='show log' οnclick='show()'/> <input type='hidden' value='01'><br> 用戶:<a id='user'></a><br> 年齡:<a id='age'></a><br> 信息:<a id='p0'></a><br> <a id='p1'></a></body><script> function show(){var number= document.getElementById('number').value;var data= {data: JSON.stringify({ ’number’: number}), }$.ajax({ url:'{{ url_for(’history’) }}', type:'post', data:data, dataType: ’json’, success:function(data){$(user).text(data.name); $(age).text(data.age); for(var i=0;i<data.mess1.length;i++){ $('#p'+i).text(data.mess1[i]);} }, error:function(e){ alert('error'); }}) }</script></html>

以上就可以簡單的實現保存并讀取本地json文件。希望能給大家一個參考,也希望大家多多支持好吧啦網。如有錯誤或未考慮完全的地方,望不吝賜教。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 久久精品国产亚洲片 | 18videosex性欧美69超高清 | 欧美日韩中文一区二区三区 | 91九色精品国产 | 中文字幕精品一区二区精品 | 怡红院男人的天堂 | 精品视频在线免费播放 | 美国毛片免费观看 | 狠狠色丁香婷婷久久综合考虑 | 日韩欧美中文字幕在线视频 | 免费国产成人18在线观看 | 国产综合在线观看 | 欧美成人午夜影院 | 俄罗斯特级毛片 | 免费看欧美一级特黄a毛片 免费看片aⅴ免费大片 | 国产欧美精品一区二区三区四区 | 亚洲韩国日本欧美一区二区三区 | 看片网站在线 | 成人欧美一区二区三区视频 | 在线aaa| 中文无线乱码二三四区 | 一级片免费视频 | 亚洲国产成人久久综合野外 | 日韩手机看片福利精品 | 日日摸夜夜搂人人要 | 亚洲夜色夜色综合网站 | 久久精品成人 | 99久久国产综合精品成人影院 | 国产成人免费影片在线观看 | 国产2021中文天码字幕 | 久久这里只有精品免费播放 | 手机看片精品国产福利盒子 | 精品视频免费在线观看 | 99精品在线播放 | 一级片一区 | 久久久免费观看视频 | 另类欧美日韩 | 福利视频黄 | 在线观看亚洲精品国产 | 欧美国产成人精品一区二区三区 | 国产成人a大片大片在线播放 |