Python如何將JavaScript轉(zhuǎn)換為json
Python將JavaScript轉(zhuǎn)換為json
當(dāng)我們讀取JavaScript后,想直接通過json.loads轉(zhuǎn)換為列表時(shí),往往會(huì)出現(xiàn)了
Error decoding JSON: Expecting property name enclosed in double quotes
例如下面的JavaScript代碼
[ { name: "Ztop", age: 21, sex: "male", country: "China", province: "GD" } ,{ name: "thirteen", age: 21, sex: "female", country: "China", province: "GD" } ]
錯(cuò)誤的出現(xiàn),可能原因
- 逗號,前面有一大堆空白
- 字典中key值沒有用雙引號括起來
- 數(shù)字value沒有用雙引號括起來
因此我們可以通過re正則排除這些可能因素
# -*-coding: Utf-8 -*- """ File: js2json.py Author: Ztop Version: V 0.1 Time: 2023/11/28 12:39 Website: https://www.zeker.top """ import json import re str_data = ''' [ { name: "Ztop", age: 21, sex: "male", country: "China", province: "GD" } ,{ name: "thirteen", age: 21, sex: "female", country: "China", province: "GD" } ] ''' # 刪除逗號前的前導(dǎo)空格 str_data = re.sub(r'\s*,', ',', str_data) # (1)將數(shù)字括到雙引號 str_data = re.sub(r': (\d+)', r': "\1"', str_data) # 匹配以單引號括起來的字符串,并將其括在雙引號中 # str_data = re.sub(r'(\w+): (\'(.*?)\')', r'"\1": "\2"', str_data) # (2)將字符串值括在雙引號中 str_data = re.sub(r'(\w+): ([\'"])(.*?)\2', r'"\1": "\3"', str_data) # Load JSON data try: data_list = json.loads(str_data) # Print or use the extracted data for item in data_list: print(item) except json.decoder.JSONDecodeError as e: print(f"Error decoding JSON: {e}")
對應(yīng)序號解釋
(1) re.sub(r': (\d+)', r': "\1"', str_data)
第一個(gè)參數(shù) r': (\d+)'
是一個(gè)正則表達(dá)式,用于匹配冒號后跟著一個(gè)或多個(gè)數(shù)字的子串。\d+
表示匹配一個(gè)或多個(gè)數(shù)字。
第二個(gè)參數(shù)r': "\1"'
是替換后的字符串。其中 \1
是一個(gè)反向引用,表示匹配正則表達(dá)式中的第一個(gè)捕獲組(即 (\d+) 匹配到的數(shù)字)。通過在雙引號內(nèi)添加 \1
,可以將匹配到的數(shù)字插入到替換后的字符串中。
(2)re.sub(r'(\w+): ([\'"])(.*?)\2', r'"\1": "\3"', str_data)
re.sub() 函數(shù)用于在字符串 str_data 中查找匹配正則表達(dá)式 ‘(\w+): ([’“])(.*?)\2’ 的子串,并將其替換為 '” \1 ": " \3 "'。
這里的正則表達(dá)式 ‘(\w+): ([’"])(.*?)\2’ 的含義如下:
- (\w+):匹配一個(gè)或多個(gè)字母、數(shù)字或下劃線字符,并將其捕獲為一個(gè)組。
- ::匹配冒號后緊跟一個(gè)空格。
- (['"]):匹配單引號或雙引號,并將其捕獲為一個(gè)組。
- (.*?):匹配任意字符零次或多次,直到遇到下一個(gè)匹配項(xiàng)。
- \2:匹配第二個(gè)捕獲組(即單引號或雙引號)的字符。
在替換字符串 ‘" \1 ": " \3 "’ 中,\1、\2 和 \3 是對應(yīng)于正則表達(dá)式中捕獲組的引用。具體來說:
- \1:對應(yīng)于第一個(gè)捕獲組,即 (\w+),表示將匹配到的單詞或短語用雙引號括起來。
- \2:對應(yīng)于第二個(gè)捕獲組,即 (['"]),表示將匹配到的單引號或雙引號用其本身括起來。
- \3:對應(yīng)于第三個(gè)捕獲組,即 (.*?),表示將匹配到的任意字符用雙引號括起來。
通過這樣的替換,最終得到的字符串 str_data 中的每個(gè)匹配項(xiàng)都會(huì)被替換為 "\1"
: "\3"
的形式,其中 \1
表示匹配到的單詞或短語,\3
表示匹配到的任意字符。
結(jié)果截圖如下:
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python使用time模塊實(shí)現(xiàn)指定時(shí)間觸發(fā)器示例
這篇文章主要介紹了Python使用time模塊實(shí)現(xiàn)指定時(shí)間觸發(fā)器,結(jié)合實(shí)例形式分析了Python時(shí)間相關(guān)模塊與方法使用技巧,需要的朋友可以參考下2017-05-05Python名片管理系統(tǒng)+猜拳小游戲案例實(shí)現(xiàn)彩(色控制臺(tái)版)
這篇文章主要介紹了Python名片管理系統(tǒng)+猜拳小游戲案例實(shí)現(xiàn)彩(色控制臺(tái)版),文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下2022-08-08Python爬蟲基礎(chǔ)之爬蟲的分類知識(shí)總結(jié)
來給大家講python爬蟲的基礎(chǔ)啦,首先我們從爬蟲的分類開始講起,下文有非常詳細(xì)的知識(shí)總結(jié),對正在學(xué)習(xí)python的小伙伴們很有幫助,需要的朋友可以參考下2021-05-05使用TensorBoard進(jìn)行超參數(shù)優(yōu)化的實(shí)現(xiàn)
這篇文章主要介紹了使用TensorBoard進(jìn)行超參數(shù)優(yōu)化的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07python爬蟲 基于requests模塊的get請求實(shí)現(xiàn)詳解
這篇文章主要介紹了python爬蟲 基于requests模塊的get請求實(shí)現(xiàn)詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08python項(xiàng)目中requirements.txt的用法實(shí)例教程
Python項(xiàng)目中必須包含一個(gè)requirements.txt文件,用于記錄所有依賴包及其精確的版本號,以便新環(huán)境部署,下面這篇文章主要給大家介紹了關(guān)于python項(xiàng)目中requirements.txt用法的相關(guān)資料,需要的朋友可以參考下2022-06-06Windows下Python使用Pandas模塊操作Excel文件的教程
Pandas是一個(gè)強(qiáng)大的Python數(shù)據(jù)分析模塊,這里我們先使用ANACONDA來幫助獲取Pandas所以來的一些環(huán)境,然后來初步學(xué)習(xí)Windows下Python使用Pandas模塊操作Excel文件的教程2016-05-05