好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > Python 如何保存json文件并格式化

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

熱門標簽:地圖標注的意義點 上海機器人外呼系統哪家好 房產電銷外呼系統 南京銷售外呼系統軟件 地圖制圖標注位置改變是移位嗎 蓋州市地圖標注 浙江電銷卡外呼系統好用嗎 315電話機器人廣告 地圖標注微信發送位置不顯示

背景

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

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

json.dump()

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

參數名 解釋
obj 要存入json文件的python對象
fp 文件句柄
ensure_ascii 設置為False的話才可以把中文以中文的形式存到文件里,否則會是'\xXX\xXX'這種
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":"大學剛畢業,她嫁給了林安森可是結婚三年,電視上??吹剿鱿鞣N場合攜女相伴,她卻再沒再親眼見過他。"
}

遞歸實現

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

# -*- encoding: utf-8 -*-
class JsonFormatter:
    def __init__(self, intend=4, name="", encoding="utf-8"):
        '''
        intend: 縮進空格數
        name: 文件名
        encoding: 文件編碼
        '''
        self.name = name
        self.intend = intend
        self.encoding = encoding
        self.stack = []
        self.obj = None
        self.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 += 1
        i = 0
        for 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 += 1
        self.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 += 1
        for 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.name
        res = ''.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文件在本地創建,打開我們可以看到數據已經成功保存:

讀取本地.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="{{ 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" id="number" 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;idata.mess1.length;i++){
                    $("#p"+i).text(data.mess1[i]);
                }
            },
            error:function(e){
                    alert("error");
            }
        })
    }
/script>
/html>

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

您可能感興趣的文章:
  • Python中json.dumps()函數的使用解析
  • python執行js代碼的方法
  • Python如何把不同類型數據的json序列化
  • python 調用js的四種方式
  • Python實現學生管理系統的代碼(JSON模塊)
  • Python解析JSON對象的全過程記錄
  • 使用python把json文件轉換為csv文件
  • Python3中對json格式數據的分析處理
  • python實現xml轉json文件的示例代碼
  • 基于telepath庫實現Python和JavaScript之間交換數據

標簽:貴州 金華 赤峰 雙鴨山 克拉瑪依 陽泉 臨汾 日照

巨人網絡通訊聲明:本文標題《Python 如何保存json文件并格式化》,本文關鍵詞  Python,如何,保存,json,文件,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Python 如何保存json文件并格式化》相關的同類信息!
  • 本頁收集關于Python 如何保存json文件并格式化的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 蜜臀视频| 日韩欧美一区二区三区久久婷婷| 骏游斗地主| 亚洲国产色图| 后进式摇摇乳猛烈XXOO动漫| 3d无遮挡h肉动漫网站免费观看| 亚洲初脱人体无圣光| 黃色A片三級三級三級免费看吃奶| 26uuu久久天堂五月色| 两个人免费完整在线观看视频在线观看| 成年女人a毛片免费视频| 在线播放国产色视频在线| 日韩?欧美?国产| 亚洲综合色婷婷婷七月丁香| 上课忘穿内裤被男同桌摸好爽口述 | 《熟妇的荡欲》免费看| 国产精品无码一区二区三区免费 | 中国小鲜肉gaytubesex| 真人性做爰无遮A片免费什么软件 免费A级毛片黄A片高清在线播放 日本一级毛一片免费视频 | 国产精品免费视频二三区| SNIS-862花绮罗在线无码| 中文字幕日韩一区二区三区不| 黄色福利网站| 伺候情侣主vk| 午夜男女刺激爽爽影院蜜芽tv| 香大伊煮香大伊煮大象大象| 肉宴(H) - 海棠书房| 色欲av人妻精品一区二| 我和公的肉欲性事TXT| 亚洲电影免费观看| 免费黄色一级视频| 黑人系列h文| 天天躁日日躁狠狠很躁| 成人扒开??伸进???91漫画| 激情五月黄色| 色视频在线播放| 免费黄色软件在线下载| 揉我奶头嗯?啊好硬好深| 久久久久综合网| 国产欧美在线一区二区三区| 欧美一级欧美一级在线播放|