2011-09-20 3 views
0

imdbpy2sql.py 스크립트를 사용하여 imdb 데이터를 텍스트 파일에서 MySQL 데이터베이스로 가져 오는 중에 문제가 있습니다.IMDbPY MySQL로 가져 오기 문제

다음과 같은 오류가 발생합니다. 예외 처리기 코드가 기존 기본 키가있는 cast_info 테이블에 복제 된 레코드를 삽입하려고 시도하는 것 같습니다.

누구든지이 문제를 해결하거나 해결책을 제안 할 수 있습니까?

SCANNING actor: Hall, Stephan 
SCANNING actor: Halsey, William F. 
* FLUSHING CharactersCache... 
* TOO MANY DATA (100000 items in CharactersCache), recursion: 1 
    * SPLITTING (run 1 of 2), recursion: 1 
* FLUSHING CharactersCache... 
Traceback (most recent call last): 
    File "D:\project\IMDB\IMDbPY-4.7\bin\imdbpy2sql.py", line 2951, in <module> 
    run() 
    File "D:\project\IMDB\IMDbPY-4.7\bin\imdbpy2sql.py", line 2812, in run 
    castLists(_charIDsList=characters_imdbIDs) 
    File "D:\project\IMDB\IMDbPY-4.7\bin\imdbpy2sql.py", line 1576, in castLists 
    doCast(f, roleid, rolename) 
    File "D:\project\IMDB\IMDbPY-4.7\bin\imdbpy2sql.py", line 1535, in doCast 
    cid = CACHE_CID.addUnique(role) 
    File "D:\project\IMDB\IMDbPY-4.7\bin\imdbpy2sql.py", line 957, in addUnique 
    else: return self.add(key, miscData) 
    File "D:\project\IMDB\IMDbPY-4.7\bin\imdbpy2sql.py", line 950, in add 
    self[key] = c 
    File "D:\project\IMDB\IMDbPY-4.7\bin\imdbpy2sql.py", line 860, in __setitem__ 
    self.flush() 
    File "D:\project\IMDB\IMDbPY-4.7\bin\imdbpy2sql.py", line 912, in flush 
    self.flush(quiet=quiet, _recursionLevel=_recursionLevel) 
    File "D:\project\IMDB\IMDbPY-4.7\bin\imdbpy2sql.py", line 883, in flush 
    self._toDB(quiet) 
    File "D:\project\IMDB\IMDbPY-4.7\bin\imdbpy2sql.py", line 1186, in _toDB 
    CURS.executemany(self.sqlstr, self.converter(l)) 
    File "C:\Python27\lib\site-packages\MySQLdb\cursors.py", line 206, in executemany 
    r = r + self.execute(query, a) 
    File "C:\Python27\lib\site-packages\MySQLdb\cursors.py", line 174, in execute 
    self.errorhandler(self, exc, value) 
    File "C:\Python27\lib\site-packages\MySQLdb\connections.py", line 36, in defaulterrorhandler 
    raise errorclass, errorvalue 
_mysql_exceptions.IntegrityError: (1062, "Duplicate entry '745684' for key 'PRIMARY'") 
+1

, --mysql - 힘의 MyISAM 사용 있는지 확인하고의 MyISAM에 MySQL의 엔진으로 설정하십시오, 나는 많이 낭비 innodb (정말로 정말로 느린 마음 당신)의 아래에서 시험해보고있는 시간 – viper

답변

4

많은 유사한 문제가 개발 버전에서 수정되었습니다. 머큐리얼 저장소의 버전으로 다시 시도하십시오 : 당신이 당신의 백엔드로 MySQL을 사용하는 경우 https://bitbucket.org/alberanid/imdbpy/