【问题标题】:Encounter: json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0)遇到:json.decoder.JSONDecodeError:期望值:第 1 行第 1 列(字符 0)
【发布时间】:2019-08-13 19:22:26
【问题描述】:

当我尝试访问我创建的 json 文件中的值时,我得到了 json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0)。我在下面运行了运行文件,似乎存在这个解码器问题,但是,当创建 json 文件时,我将应该添加到 json 文件字典中的加密内容作为字符串。有人可以帮我找出问题所在吗?

错误是:

{
    "youtube": {
        "key": "D5IPLv06NGXut4kKdScNAP47AieP8wqeUINr6EFLXFs=",
        "content": "gAAAAABclST8_XmHrAAfEbgrX-r6wwrJf7IAtDoLSkahXAraPjvoXeLl3HLkuHbW0uj5XpR4_jmkgk0ICmT8ZKP267-nnjnCpw=="
    },
    "facebook": {
        "key": "YexP5dpgxwKhD8Flr6hbJhMiAB1nmzZXi2IMMO3agXg=",
        "content": "gAAAAABclST8zSRen_0sur79NQk9Pin16PZcg95kEHnFt5vjKENMPckpnK9JQctayouQ8tHHeRNu--s58Jj3IPsPbrLoeOwr-mwdU5KvvaXLY-g6bUwnIp4="
    },
    "instagram": {
        "key": "ew2bl0tKdlgwiWfhB0jjSrOZDb41F88HULCQ_21EDGU=",
        "content": "gAAAAABclST8FKcZqasiXfARRfbGPqb3pdDj4aKuxeJoRvgIPbVIOZEa5s34f0c_H3_itv5iG1O7u8vvlT8lAPTgAp3ez8OBh4T2OfBG-ObljYmIt7exi0Q="
    }
}
Traceback (most recent call last):
  File "C:\Users\YOURNAME\Desktop\randomprojects\content_key_writer.py", line 65, in <module>
    main()
  File "C:\Users\YOURNAME\Desktop\randomprojects\content_key_writer.py", line 60, in main
    data_content = json.load(data_file)
  File "C:\Users\YOURNAME\AppData\Local\Programs\Python\Python37\lib\json\__init__.py", line 296, in load
    parse_constant=parse_constant, object_pairs_hook=object_pairs_hook, **kw)
  File "C:\Users\YOURNAME\AppData\Local\Programs\Python\Python37\lib\json\__init__.py", line 348, in loads
    return _default_decoder.decode(s)
  File "C:\Users\YOURNAME\AppData\Local\Programs\Python\Python37\lib\json\decoder.py", line 337, in decode
    obj, end = self.raw_decode(s, idx=_w(s, 0).end())
  File "C:\Users\YOURNAME\AppData\Local\Programs\Python\Python37\lib\json\decoder.py", line 355, in raw_decode
    raise JSONDecodeError("Expecting value", s, err.value) from None
json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0)

这里贴的是原始代码,命名为runfile:

import sys
import os
from cryptography.fernet import Fernet
import json
import pathlib
from encipher_decipher import encrypt, decrypt, bytes_to_str, str_to_bytes 

def content_key_writer(path, filename, account, content):
    """Generate key corresponding to an account, save in json"""
    # make the path a Path object
    path = pathlib.Path(path)
    file_path = os.path.join(path, filename)

    # generate a key using Fernet
    key = Fernet.generate_key()
    # json doesn't support bytes, so convert to string
    key = bytes_to_str(key)

    # with file_path, see if the file exists
    if not os.path.exists(file_path):
        # build the dictionary to hold key and content
        data = {}
        data[account] = {}
        data[account]['key'] = key
        data[account]['content'] = encrypt(content, key)


        # if the file doesn't exist, build the new json file
        with open(file_path, 'w') as f:
            json.dump(data, f)
    else:
        # if the file does exist
        with open(file_path, 'r') as f:
            data = json.load(f)
            data[account] = {} # <--- add the account 
            data[account]['key'] = key
            data[account]['content'] = encrypt(content, key)

        os.remove(file_path) # <--- remove the file and rewrite it
        with open(file_path, 'w') as f:
            json.dump(data, f, indent=4)

def main():
    path = "C:/Users/YOURNAME/Desktop/randomprojects"
    name = 'content.json'
    account = 'youtube'
    content = 'youtubepassword'
    account2 = 'facebook'
    content2 = 'facebookpassword'
    account3 = 'instagram'
    content3 = 'instagrampassword'

    content_key_writer(path, name, account, content)
    content_key_writer(path, name, account2, content2)
    content_key_writer(path, name, account3, content3)
    new_path = os.path.join(pathlib.Path(path),name)
    with open(new_path) as data_file:
        data = data_file.read()
        print(data) 
        data_content = json.load(data_file)
    value = data_content['youtube']['content']
    print(value)

if __name__ == '__main__':
    main()

上面代码中导入的模块是encipher_decipher:

"""
Given an information, encrypt and decrypt using the given key
"""

from cryptography.fernet import Fernet
import os

def encrypt(information, key):
    """encrypt information and return as string"""
    f = Fernet(key)
    information_bytes = str_to_bytes(information) 
    encrypted_info = f.encrypt(information_bytes) #<--- returns bytes
    encrypted_info = bytes_to_str(encrypted_info) #<--- to save in json requires str not bytes
    return encrypted_info

def decrypt(information, key):
    """decrypt information and return as string"""
    f = Fernet(key)
    information_bytes = str_to_bytes(information)
    decrypted_info = f.decrypt(information_bytes) #<--- returns bytes
    decrypted_info = bytes_to_str(decrypted_info) #<--- converts to string
    return decrypted_info

def bytes_to_str(byte_stuff):
    """Convert bytes to string"""
    return byte_stuff.decode('utf-8')

def str_to_bytes(str_stuff):
    """Converts string to bytes"""
    return bytes(str_stuff, 'utf-8') # or str_stuff.encode('utf-8')

【问题讨论】:

  • 我在文件中试过了,使用 json.loads() 返回错误,而使用 json.load() 没有问题。但是在使用 json.load() 之后,我仍然无法访问这些值。
  • 尝试创建一个minimal reproducible example 供人们用来重现(并可能修复)问题。
  • 试试这个stackoverflow.com/questions/5406172/utf-8-without-bom。我使用的 json 文件在标题处有 BOM 信息,即在 json 数据开始之前的字符 。必须使用编辑器删除 BOM,然后它才起作用。

标签: python json python-3.x dictionary encryption


【解决方案1】:

问题是这段代码:

with open(new_path) as data_file:
  data = data_file.read()
  print(data) 
  data_content = json.load(data_file)

您正在将文件的内容读入data,打印它,然后要求json.load() 再次从文件句柄中读取。但是此时文件指针已经在文件末尾,所以没有更多数据,因此 json 错误:Expecting value

改为这样做:

with open(new_path) as data_file:
  data = data_file.read()
  print(data) 
  data_content = json.loads(data)

您已经将数据读入data,因此您可以将该字符串输入json.loads()

【讨论】:

  • 是的,没错,我也通过loads(data_file.read()) 做了同样的事情,结果很好。非常感谢。
  • 非常不错的收获!
猜你喜欢
  • 2023-03-25
  • 2020-11-11
  • 2017-05-09
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2021-10-21
  • 1970-01-01
相关资源
最近更新 更多