Python 类型错误:';非类型';对象不可用于JSON分析

Python 类型错误:';非类型';对象不可用于JSON分析,python,json,request,Python,Json,Request,我试图使用python从第1页到第20页中提取事件的费用信息。活动费用来自外部URL。因此,我需要使用json load解析它,并从json文件中提取模式。我尝试了这段代码,得到了以下错误TypeError:“NoneType”对象不可下标。根据我的研究,这意味着对象等于零,因此不可下标 如果值为None,我尝试将对象分配给“NA”,但仍然没有成功。如果有人能解释一下,我将不胜感激。下面是我尝试过的代码: import re import json import requests event_

我试图使用python从第1页到第20页中提取事件的费用信息。活动费用来自外部URL。因此,我需要使用json load解析它,并从json文件中提取模式。我尝试了这段代码,得到了以下错误
TypeError:“NoneType”对象不可下标
。根据我的研究,这意味着对象等于零,因此不可下标

如果值为None,我尝试将对象分配给“NA”,但仍然没有成功。如果有人能解释一下,我将不胜感激。下面是我尝试过的代码:

import re
import json
import requests

event_fees = []

for i in range(20):
    
    urls = 'https://www.eventbrite.com/d/malaysia--kuala-lumpur--85675181/all-events/?page=' + str(i)
    
    events_url = 'https://www.eventbrite.com/api/v3/destination/events/?event_ids={event_ids}&expand=event_sales_status,primary_venue,image,saves,my_collections,ticket_availability&page_size=99999'
    
    html_text = requests.get(urls).text
    
    data1 = json.loads( re.search(r'window\.__SERVER_DATA__ = ({.*});', html_text).group(1) )
    
    event_ids = ','.join(r['id'] for r in data1['search_data']['events']['results'])
    data2 = requests.get(events_url.format(event_ids=event_ids)).json()
    
    for e in data2['events']:
        fees = (e['ticket_availability']['minimum_ticket_price']['display'],'to',e['ticket_availability']['maximum_ticket_price']['display'])
        if fees is None:
            
            event_fees.append("NA")
        
        else:
            
            event_fees.append(fees)


在使用订阅之前检查该对象中是否有密钥(
obj['key']
)。在这种情况下,
data2[6]['ticket\u availability']['minimum\u ticket\u price']
None

您的问题是什么?您似乎知道如何编写
if
语句来检查某个对象是否为
None
,为什么不对出现错误的对象执行相同的操作?我需要编写代码,以便在对象为None时,它将NA分配给事件费用列表,而如果它们是对象中的费用值,它会将费用值附加到事件费用中。这是任务描述,不是问题。是什么阻止了你这么做?我发现这个“非类型”对象是不可订阅的,我不知道如何解决。在尝试使用它之前,你需要检查该对象是否为
None
。如果是
None
,则需要执行其他操作(例如,不执行任何操作)。既然您已经在代码中使用了
if fees is None
,我想知道您为什么不在需要的地方使用另一个这样的检查。如果密钥为None(无费用),我如何将其分配为'NA'并将其传递给event_费用列表,而如果其他对象具有费用值,它将附加到event_费用列表中。