オープン ソース データベースである freebase にクエリを実行する Python スクリプトを作成しました。ファイルを Windows で作成し、Linux に移植しました。ファイルのアクセス許可を変更し、適切なヘッダーを追加しましたが、Linux シェルは次のように返します。
そのようなファイル、又はディレクトリはありません
ファイルは次のとおりです。
#! /usr/bin/env python
import urllib
import string
#query freebase to find results containing graduates from the University of Texas
query1=[{
"name": null,
"type": "/people/person",
"!/education/education/student": [{
"!/education/educational_institution/students_graduates": [{
"id": "/en/university_of_texas"
}]
}]
}]
query2=[{
"id": "/en/university_of_texas",
"/education/educational_institution/students_graduates": [{
"student": {
"name": null
},
"degree": {
"name": null
},
"end_date": null,
"major_field_of_study": [{
"name": null
}]
}]
}]
html = urllib.urlopen("https://www.googleapis.com/freebase/v1/mqlread?query="+query2)
library = json.loads(html)
name_dic = {}
for e in library["result"]:
name_dic[e["student"]["name"]] = [e["degree"]["name"],int(e["end_date"]),e["major_field_of_study"][0]["name"]]
conn = sqlite3.connect('data.db')
c = conn.cursor()
t=[]
for key in name_dic.iterkeys():
t.append((key, name_dic[key][0],name_dic[key][1],name_dic[key][2]))
try:
c.executemany('insert into people values(?,?,?,?)',t)
print "entities found and saved"
except sqlite3.IntegrityError:
for k in t:
try:
c.execute('insert into people values (?,?,?,?)',k)
print (str(k[0])+" was added")
except sqlite3.IntegrityError:
print "Could not save entities"
conn.commit()