Python如何將JavaScript轉(zhuǎn)換為json
Python將JavaScript轉(zhuǎn)換為json
當(dāng)我們讀取JavaScript后,想直接通過(guò)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),可能原因
- 逗號(hào),前面有一大堆空白
- 字典中key值沒(méi)有用雙引號(hào)括起來(lái)
- 數(shù)字value沒(méi)有用雙引號(hào)括起來(lái)
因此我們可以通過(guò)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"
}
]
'''
# 刪除逗號(hào)前的前導(dǎo)空格
str_data = re.sub(r'\s*,', ',', str_data)
# (1)將數(shù)字括到雙引號(hào)
str_data = re.sub(r': (\d+)', r': "\1"', str_data)
# 匹配以單引號(hào)括起來(lái)的字符串,并將其括在雙引號(hào)中
# str_data = re.sub(r'(\w+): (\'(.*?)\')', r'"\1": "\2"', str_data)
# (2)將字符串值括在雙引號(hào)中
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}")對(duì)應(yīng)序號(hào)解釋
(1) re.sub(r': (\d+)', r': "\1"', str_data)
第一個(gè)參數(shù) r': (\d+)' 是一個(gè)正則表達(dá)式,用于匹配冒號(hào)后跟著一個(gè)或多個(gè)數(shù)字的子串。\d+ 表示匹配一個(gè)或多個(gè)數(shù)字。
第二個(gè)參數(shù)r': "\1"'是替換后的字符串。其中 \1 是一個(gè)反向引用,表示匹配正則表達(dá)式中的第一個(gè)捕獲組(即 (\d+) 匹配到的數(shù)字)。通過(guò)在雙引號(hào)內(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è)組。
- ::匹配冒號(hào)后緊跟一個(gè)空格。
- (['"]):匹配單引號(hào)或雙引號(hào),并將其捕獲為一個(gè)組。
- (.*?):匹配任意字符零次或多次,直到遇到下一個(gè)匹配項(xiàng)。
- \2:匹配第二個(gè)捕獲組(即單引號(hào)或雙引號(hào))的字符。
在替換字符串 ‘" \1 ": " \3 "’ 中,\1、\2 和 \3 是對(duì)應(yīng)于正則表達(dá)式中捕獲組的引用。具體來(lái)說(shuō):
- \1:對(duì)應(yīng)于第一個(gè)捕獲組,即 (\w+),表示將匹配到的單詞或短語(yǔ)用雙引號(hào)括起來(lái)。
- \2:對(duì)應(yīng)于第二個(gè)捕獲組,即 (['"]),表示將匹配到的單引號(hào)或雙引號(hào)用其本身括起來(lái)。
- \3:對(duì)應(yīng)于第三個(gè)捕獲組,即 (.*?),表示將匹配到的任意字符用雙引號(hào)括起來(lái)。
通過(guò)這樣的替換,最終得到的字符串 str_data 中的每個(gè)匹配項(xiàng)都會(huì)被替換為 "\1": "\3" 的形式,其中 \1表示匹配到的單詞或短語(yǔ),\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-05
Python名片管理系統(tǒng)+猜拳小游戲案例實(shí)現(xiàn)彩(色控制臺(tái)版)
這篇文章主要介紹了Python名片管理系統(tǒng)+猜拳小游戲案例實(shí)現(xiàn)彩(色控制臺(tái)版),文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下2022-08-08
Python爬蟲(chóng)基礎(chǔ)之爬蟲(chóng)的分類知識(shí)總結(jié)
來(lái)給大家講python爬蟲(chóng)的基礎(chǔ)啦,首先我們從爬蟲(chóng)的分類開(kāi)始講起,下文有非常詳細(xì)的知識(shí)總結(jié),對(duì)正在學(xué)習(xí)python的小伙伴們很有幫助,需要的朋友可以參考下2021-05-05
使用TensorBoard進(jìn)行超參數(shù)優(yōu)化的實(shí)現(xiàn)
這篇文章主要介紹了使用TensorBoard進(jìn)行超參數(shù)優(yōu)化的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07
python爬蟲(chóng) 基于requests模塊的get請(qǐng)求實(shí)現(xiàn)詳解
這篇文章主要介紹了python爬蟲(chóng) 基于requests模塊的get請(qǐng)求實(shí)現(xiàn)詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08
python項(xiàng)目中requirements.txt的用法實(shí)例教程
Python項(xiàng)目中必須包含一個(gè)requirements.txt文件,用于記錄所有依賴包及其精確的版本號(hào),以便新環(huán)境部署,下面這篇文章主要給大家介紹了關(guān)于python項(xiàng)目中requirements.txt用法的相關(guān)資料,需要的朋友可以參考下2022-06-06
Windows下Python使用Pandas模塊操作Excel文件的教程
Pandas是一個(gè)強(qiáng)大的Python數(shù)據(jù)分析模塊,這里我們先使用ANACONDA來(lái)幫助獲取Pandas所以來(lái)的一些環(huán)境,然后來(lái)初步學(xué)習(xí)Windows下Python使用Pandas模塊操作Excel文件的教程2016-05-05

