2014-09-01 5 views
0

아래 코드는 제가 가지고있는 코드입니다. 나는 위의 코드와 함께 할 노력하고있어TypeError : 목록 인덱스는 JSON 파일의 str이 아닌 정수 여야합니다.

  fullsrcurl = self.srcjson + format_type + '&jobname=' + joburl 
      srcfile = urllib2.urlopen(fullsrcurl) 
      if self.format_export == 'json': 
       srcdata = json.load(srcfile) 
       pprint(srcdata) 
       srcjobmst_id = srcdata["jobmst_id"][0] 

는 JSON을 반환하고 JSON에서 'jobmst_id'값을 얻을 수있어하는 API의 URL에서 읽습니다. pprint (srcdata는 아래의 json을 제공합니다)에서 jobmst_id 값을 가져오고 싶습니다.이 경우 아래의 경우 '58908'이됩니다. 나는 그것을 변환 할 수있는 정수로 기꺼이 받아 들일 것이지만, 지금 당장은 그것이 그 주체의 오류가있는 줄에서 실패한다.

[{u'evntmst_id': {u'evntmst_calendar': 0, 
        u'evntmst_crttm': u'2009-12-04T11:22:03', 
        u'evntmst_desc': None, 
        u'evntmst_fiscal': 0, 
        u'evntmst_frcstdt': u'2012-12-31T00:00:00', 
        u'evntmst_freq': 1, 
        u'evntmst_fromdt': None, 
        u'evntmst_id': 1, 
        u'evntmst_intsect': u'N', 
        u'evntmst_lstchgtm': u'2009-12-04T12:28:52', 
        u'evntmst_lstcmptm': u'2014-08-28T12:00:29', 
        u'evntmst_monthdays': u'YYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYY', 
        u'evntmst_months': u'YYYYYYYYYYYY', 
        u'evntmst_name': u'Daily 
       ', 
        u'evntmst_occur': 0, 
        u'evntmst_offset': 0, 
        u'evntmst_owner': 2, 
        u'evntmst_public': u'Y', 
        u'evntmst_subtype': None, 
        u'evntmst_timeframe': 0, 
        u'evntmst_totcnt': None, 
        u'evntmst_type': 2, 
        u'evntmst_untildt': u'2012-12-31T00:00:00', 
        u'evntmst_weekdays': u'YYYYYYY', 
        u'evntmst_weeks': u'NNNNN'}, 
    u'job_dependencies': [], 
    u'job_events': [], 
    u'jobcls_id': None, 
    u'jobdtl_id': {u'jobdtl_abrtonclderr': None, 
       u'jobdtl_allowadhoc': u'Y', 
       u'jobdtl_carryover': 1, 
       u'jobdtl_cmd': None, 
       u'jobdtl_concur': 1, 
       u'jobdtl_deplogic': 1, 
       u'jobdtl_deprerun': u'N', 
       u'jobdtl_duration': 67, 
       u'jobdtl_envfile': None, 
       u'jobdtl_estdurexclude': 4, 
       u'jobdtl_estmethod': 1, 
       u'jobdtl_extinfo': None, 
       u'jobdtl_failalarm': None, 
       u'jobdtl_fromdt': u'2012-11-22T00:00:00', 
       u'jobdtl_fromtm': u'1899-12-30T23:30:00', 
       u'jobdtl_id': 58908, 
       u'jobdtl_inhagent': u'N', 
       u'jobdtl_inhevent': u'N', 
       u'jobdtl_inhoptions': u'N', 
       u'jobdtl_inhrepeat': u'N', 
       u'jobdtl_inhtime': u'N', 
       u'jobdtl_interval': None, 
       u'jobdtl_intervalcnt': None, 
       u'jobdtl_maxrun': 60, 
       u'jobdtl_minrun': 60, 
       u'jobdtl_nearoutage': 3, 
       u'jobdtl_normalexit': 0, 
       u'jobdtl_normalop': 1, 
       u'jobdtl_normalrange': 0, 
       u'jobdtl_outputname': None, 
       u'jobdtl_params': None, 
       u'jobdtl_priority': 50, 
       u'jobdtl_proxy': 4, 
       u'jobdtl_proxy2': None, 
       u'jobdtl_psjob': None, 
       u'jobdtl_rerun': None, 
       u'jobdtl_rerunok': u'Y', 
       u'jobdtl_retnsn': 30, 
       u'jobdtl_sapcount': None, 
       u'jobdtl_savelogonly': u'N', 
       u'jobdtl_saveoutput': u'Y', 
       u'jobdtl_statuscl': None, 
       u'jobdtl_timewin': 2, 
       u'jobdtl_trackcl': None, 
       u'jobdtl_trackcmd': None, 
       u'jobdtl_trackmethod': 1, 
       u'jobdtl_trxid': None, 
       u'jobdtl_unit': None, 
       u'jobdtl_untildt': u'1899-12-30T00:00:00', 
       u'jobdtl_untiltm': u'1899-12-30T23:50:00', 
       u'jobdtl_waitop': u'N', 
       u'jobdtl_workdir': None, 
       u'nodlstmst_id': 27, 
       u'nodmst_id': None, 
       u'servicemst_id': None}, 
    u'jobmst_active': u'Y', 
    u'jobmst_alias': u'58908  ', 
    u'jobmst_crttm': u'2012-11-22T12:22:59', 
    u'jobmst_desc': None, 
    u'jobmst_dirty': u' ', 
    u'jobmst_evntoffset': None, 
    u'jobmst_id': 58908, 
    u'jobmst_lstchgtm': u'2012-11-22T13:01:34', 
    u'jobmst_mode': 0, 
    u'jobmst_name': u'SWIFT DB Backup', 
    u'jobmst_owner': {u'owner_allagents': u'Y', 
        u'owner_id': 257, 
        u'owner_name': u'Common      ', 
        u'owner_type': 2}, 
    u'jobmst_prntid': None, 
    u'jobmst_prntname': None, 
    u'jobmst_type': 1, 
    u'runbook_url': None}] 
+1

JSON의 시작 부분이 포함되어 있지 않습니다. JSON의 시작 부분은 유효해야하기 때문에}와]가 있어야합니다. 그리고 그것은 여러분의 질문에 대한 답입니다. 그것은 사전이 아닌 사전이있는 목록으로 돌아옵니다. jobmst_id [ "jobmst_id"] [0]'이 아니라'srcdata [0] [ "jobmst_id"]'를하고 싶었다. –

+0

json이 유효합니다. 전체 파일을 업데이트했습니다. 너무 많은 코드에 대해 불평했기 때문에 나는 그것을 다듬어야했다. – whoisearth

답변

1

데이터가 srcdata[0]["jobmst_id"]하지 srcdata["jobmst_id"][0]입니다 검색하는 방법 - 아래

는 JSON이다.

관련 문제