欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python如何將JavaScript轉(zhuǎn)換為json

 更新時(shí)間:2025年02月05日 09:42:41   作者:Ztop  
文章介紹了如何使用Python的re模塊將JavaScript代碼轉(zhuǎn)換為JSON格式,首先,使用正則表達(dá)式匹配并替換JavaScript代碼中的數(shù)字,確保它們被雙引號括起來,然后,使用另一個(gè)正則表達(dá)式匹配并替換JavaScript代碼中的鍵值對,確保鍵和值都被雙引號括起來

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),可能原因

  1. 逗號,前面有一大堆空白
  2. 字典中key值沒有用雙引號括起來
  3. 數(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ā)器示例

    這篇文章主要介紹了Python使用time模塊實(shí)現(xiàn)指定時(shí)間觸發(fā)器,結(jié)合實(shí)例形式分析了Python時(shí)間相關(guān)模塊與方法使用技巧,需要的朋友可以參考下
    2017-05-05
  • 利用Pygame繪制圓環(huán)的示例代碼

    利用Pygame繪制圓環(huán)的示例代碼

    這篇文章主要介紹了利用Python中的Pygame模塊繪制一個(gè)彩色的圓環(huán),文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)Pygame有一定幫助,需要的可以參考一下
    2022-01-01
  • Python名片管理系統(tǒng)+猜拳小游戲案例實(shí)現(xiàn)彩(色控制臺(tái)版)

    Python名片管理系統(tǒng)+猜拳小游戲案例實(shí)現(xiàn)彩(色控制臺(tái)版)

    這篇文章主要介紹了Python名片管理系統(tǒng)+猜拳小游戲案例實(shí)現(xiàn)彩(色控制臺(tái)版),文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下
    2022-08-08
  • Python爬蟲基礎(chǔ)之爬蟲的分類知識(shí)總結(jié)

    Python爬蟲基礎(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)

    這篇文章主要介紹了使用TensorBoard進(jìn)行超參數(shù)優(yōu)化的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • 如何利用python讀取micaps文件詳解

    如何利用python讀取micaps文件詳解

    這篇文章主要給大家介紹了關(guān)于如何利用python讀取micaps文件的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • python爬蟲 基于requests模塊的get請求實(shí)現(xiàn)詳解

    python爬蟲 基于requests模塊的get請求實(shí)現(xiàn)詳解

    這篇文章主要介紹了python爬蟲 基于requests模塊的get請求實(shí)現(xiàn)詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-08-08
  • python項(xiàng)目中requirements.txt的用法實(shí)例教程

    python項(xiàng)目中requirements.txt的用法實(shí)例教程

    Python項(xiàng)目中必須包含一個(gè)requirements.txt文件,用于記錄所有依賴包及其精確的版本號,以便新環(huán)境部署,下面這篇文章主要給大家介紹了關(guān)于python項(xiàng)目中requirements.txt用法的相關(guān)資料,需要的朋友可以參考下
    2022-06-06
  • python中私有函數(shù)調(diào)用方法解密

    python中私有函數(shù)調(diào)用方法解密

    這篇文章主要介紹了python中私有函數(shù)調(diào)用方法,較為詳細(xì)的分析了Python私有函數(shù)的原理與調(diào)用技巧,需要的朋友可以參考下
    2016-04-04
  • Windows下Python使用Pandas模塊操作Excel文件的教程

    Windows下Python使用Pandas模塊操作Excel文件的教程

    Pandas是一個(gè)強(qiáng)大的Python數(shù)據(jù)分析模塊,這里我們先使用ANACONDA來幫助獲取Pandas所以來的一些環(huán)境,然后來初步學(xué)習(xí)Windows下Python使用Pandas模塊操作Excel文件的教程
    2016-05-05

最新評論