本文整理匯總了Python中app.db方法的典型用法代碼示例。如果您正苦於以下問題:Python app.db方法的具體用法?Python app.db怎麽用?Python app.db使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類app
的用法示例。
在下文中一共展示了app.db方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: parse_update_optional_args
# 需要導入模塊: import app [as 別名]
# 或者: from app import db [as 別名]
def parse_update_optional_args(parser):
# just for updating lots
parser.add_argument('--limit', "-l", nargs="?", type=int, help="how many jobs to do")
parser.add_argument('--chunk', "-ch", nargs="?", default=10, type=int, help="how many to take off db at once")
parser.add_argument('--after', nargs="?", type=str, help="minimum id or id start, ie 0000-0001")
parser.add_argument('--rq', action="store_true", default=False, help="do jobs in this thread")
parser.add_argument('--order', action="store_true", default=True, help="order them")
parser.add_argument('--append', action="store_true", default=False, help="append, dont' clear queue")
parser.add_argument('--name', nargs="?", type=str, help="name for the thread")
# just for updating one
parser.add_argument('--id', nargs="?", type=str, help="id of the one thing you want to update")
parser.add_argument('--doi', nargs="?", type=str, help="doi of the one thing you want to update")
# parse and run
parsed_args = parser.parse_args()
return parsed_args
示例2: run_update
# 需要導入模塊: import app [as 別名]
# 或者: from app import db [as 別名]
def run_update(parsed_args):
update = update_registry.get(parsed_args.fn)
start = time()
#convenience method for handling an doi
if parsed_args.doi:
from pub import Pub
from util import clean_doi
my_pub = db.session.query(Pub).filter(Pub.id==clean_doi(parsed_args.doi)).first()
parsed_args.id = my_pub.id
logger.info(u"Got database hit for this doi: {}".format(my_pub.id))
update.run(**vars(parsed_args))
db.session.remove()
logger.info(u"finished update in {} secconds".format(elapsed(start)))
示例3: add_pubs_or_update_crossref
# 需要導入模塊: import app [as 別名]
# 或者: from app import db [as 別名]
def add_pubs_or_update_crossref(pubs):
if not pubs:
return []
pubs_by_id = dict((p.id, p) for p in pubs)
existing_pub_ids = set([
id_tuple[0] for id_tuple in db.session.query(Pub.id).filter(Pub.id.in_(pubs_by_id.keys())).all()
])
pubs_to_add = [p for p in pubs if p.id not in existing_pub_ids]
pubs_to_update = [p for p in pubs if p.id in existing_pub_ids]
if pubs_to_add:
logger.info(u"adding {} pubs".format(len(pubs_to_add)))
db.session.add_all(pubs_to_add)
if pubs_to_update:
row_dicts = [{'id': p.id, 'crossref_api_raw_new': p.crossref_api_raw_new} for p in pubs_to_update]
logger.info(u"updating {} pubs".format(len(pubs_to_update)))
db.session.bulk_update_mappings(Pub, row_dicts)
safe_commit(db)
return pubs_to_add
示例4: check_pdf_urls
# 需要導入模塊: import app [as 別名]
# 或者: from app import db [as 別名]
def check_pdf_urls(pdf_urls):
for url in pdf_urls:
make_transient(url)
# free up the connection while doing net IO
safe_commit(db)
db.engine.dispose()
req_pool = get_request_pool()
checked_pdf_urls = req_pool.map(get_pdf_url_status, pdf_urls, chunksize=1)
req_pool.close()
req_pool.join()
row_dicts = [x.__dict__ for x in checked_pdf_urls]
for row_dict in row_dicts:
row_dict.pop('_sa_instance_state')
db.session.bulk_update_mappings(PdfUrl, row_dicts)
start_time = time()
commit_success = safe_commit(db)
if not commit_success:
logger.info(u"COMMIT fail")
logger.info(u"commit took {} seconds".format(elapsed(start_time, 2)))
示例5: after_request_stuff
# 需要導入模塊: import app [as 別名]
# 或者: from app import db [as 別名]
def after_request_stuff(resp):
#support CORS
resp.headers['Access-Control-Allow-Origin'] = "*"
resp.headers['Access-Control-Allow-Methods'] = "POST, GET, OPTIONS, PUT, DELETE, PATCH"
resp.headers['Access-Control-Allow-Headers'] = "origin, content-type, accept, x-requested-with"
# remove session
db.session.remove()
# without this jason's heroku local buffers forever
sys.stdout.flush()
# log request for analytics
log_request(resp)
return resp
示例6: accuracy_report
# 需要導入模塊: import app [as 別名]
# 或者: from app import db [as 別名]
def accuracy_report():
reports = []
subset_q = "select distinct input_batch_name from accuracy_from_mturk"
subsets = get_sql_answers(db, subset_q)
# subsets = ["articlelike_all_years"]
for subset in subsets:
reports.append(AccuracyReport(test_set=subset, no_rg_or_academia=True))
reports.append(AccuracyReport(test_set=subset, genre='journal-article', no_rg_or_academia=True))
reports.append(AccuracyReport(test_set=subset, since_2017=True, no_rg_or_academia=True))
reports.append(AccuracyReport(test_set=subset, before_2008=True, no_rg_or_academia=True))
for report in reports:
report.build_current_report()
return jsonify({"response": [report.to_dict() for report in reports]})
示例7: add_pmh_record
# 需要導入模塊: import app [as 別名]
# 或者: from app import db [as 別名]
def add_pmh_record(self, **kwargs):
endpoint_id = kwargs.get("id", None)
record_id = kwargs.get("recordid")
my_repo = Endpoint.query.get(endpoint_id)
print "my_repo", my_repo
my_pmh_record = my_repo.get_pmh_record(record_id)
my_pmh_record.mint_pages()
# for my_page in my_pmh_record.pages:
# print "my_page", my_page
# my_page.scrape()
my_pmh_record.delete_old_record()
db.session.merge(my_pmh_record)
# print my_pmh_record.pages
safe_commit(db)
示例8: save_repo_request_rows
# 需要導入模塊: import app [as 別名]
# 或者: from app import db [as 別名]
def save_repo_request_rows(rows):
with open('out.csv','wb') as f:
w = csv.DictWriter(f, fieldnames=RepoRequest.list_fieldnames(), encoding='utf-8-sig')
for row in rows[1:]: # skip header row
my_repo_request = RepoRequest()
my_repo_request.set_id_seed(row[0])
column_num = 0
for fieldname in RepoRequest.list_fieldnames():
if fieldname != "id":
setattr(my_repo_request, fieldname, row[column_num])
column_num += 1
w.writerow(my_repo_request.to_dict())
print u"adding repo request {}".format(my_repo_request)
db.session.merge(my_repo_request)
safe_commit(db)
示例9: from_bq_overwrite_data
# 需要導入模塊: import app [as 別名]
# 或者: from app import db [as 別名]
def from_bq_overwrite_data(db_tablename, bq_tablename):
temp_data_filename = 'data_export.csv'
column_names = from_bq_to_local_file(temp_data_filename, bq_tablename, header=False)
print "column_names", column_names
print "\n"
cursor = db.session.connection().connection.cursor()
cursor.execute(u"truncate {};".format(db_tablename))
with open(temp_data_filename, "rb") as f:
cursor.copy_from(f, db_tablename, sep='\t', columns=column_names, null="")
# this commit is necessary
safe_commit(db)
# python bigquery_import.py --db pmh_record --bq pmh.pmh_record
示例10: removeServices
# 需要導入模塊: import app [as 別名]
# 或者: from app import db [as 別名]
def removeServices(serviceid):
logging.info('Remove the service %s', serviceid)
try:
docker_client = docker.from_env()
docker_remove = docker_client.services.get(serviceid)
docker_remove.remove()
remove_ser = models.Service.query.all()
for i in remove_ser:
if (i.serviceid == serviceid):
db.session.delete(i)
db.session.commit()
break
except docker.errors.APIError as e:
if e.status_code == 404:
remove_ser = models.Service.query.all()
for i in remove_ser:
if (i.serviceid == serviceid):
db.session.delete(i)
db.session.commit()
break
else:
logging.error('Unable to remove the service %s. \nReason: %s', serviceid, str(e))
示例11: deleteImage
# 需要導入模塊: import app [as 別名]
# 或者: from app import db [as 別名]
def deleteImage(image_name):
logging.info('Delete the image %s', image_name)
try:
docker_client = docker.from_env()
registry_imagename = registry + '/' + image_name
docker_client.images.remove(image=registry_imagename,force=True)
image = models.Image.query.filter_by(imagename=image_name).first()
db.session.delete(image)
db.session.commit()
except docker.errors.APIError as e:
image = models.Image.query.filter_by(imagename = image_name).first()
db.session.delete(image)
db.session.commit()
error_string = 'Unable to delete the image {}. \nReason: {}. Delete the record'.format(registry_imagename, str(e))
logging.error(error_string)
return error_string
return None
示例12: signup
# 需要導入模塊: import app [as 別名]
# 或者: from app import db [as 別名]
def signup():
from forms import SignupForm
form = SignupForm()
if form.validate_on_submit():
user = User.query.filter_by(email=form.email.data.lower()).first()
if user is not None:
form.email.errors.append("The Email address is already taken.")
return render_template('signup.html', form=form)
newuser = User(form.firstname.data,form.lastname.data,form.email.data,form.password.data)
db.session.add(newuser)
db.session.commit()
session['email'] = newuser.email
return redirect(url_for('login'))
return render_template('signup.html', form=form)
示例13: ping
# 需要導入模塊: import app [as 別名]
# 或者: from app import db [as 別名]
def ping(service_id):
from app import db, models
from models import Service
finding = Service.query.filter_by(serviceid=service_id).first()
if finding is not None:
image_name = finding.imagename
uploadn = finding.uploadname
usern = finding.username
firstcreatetime = finding.firstcreatetime
u = Service(serviceid = service_id, createdtime = str(time.time()), imagename = image_name, uploadname = uploadn, username = usern, firstcreatetime = firstcreatetime)
db.session.add(u)
db.session.commit()
db.session.delete(finding)
db.session.commit()
else:
return "The service "+service_id+" has been removed!"
return "There are existing service:"+service_id
示例14: backfill_notification_statuses
# 需要導入模塊: import app [as 別名]
# 或者: from app import db [as 別名]
def backfill_notification_statuses():
"""
DEPRECATED. Populates notification_status.
This will be used to populate the new `Notification._status_fkey` with the old
`Notification._status_enum`
"""
LIMIT = 250000
subq = "SELECT id FROM notification_history WHERE notification_status is NULL LIMIT {}".format(LIMIT)
update = "UPDATE notification_history SET notification_status = status WHERE id in ({})".format(subq)
result = db.session.execute(subq).fetchall()
while len(result) > 0:
db.session.execute(update)
print('commit {} updates at {}'.format(LIMIT, datetime.utcnow()))
db.session.commit()
result = db.session.execute(subq).fetchall()
示例15: update_notification_international_flag
# 需要導入模塊: import app [as 別名]
# 或者: from app import db [as 別名]
def update_notification_international_flag():
"""
DEPRECATED. Set notifications.international=false.
"""
# 250,000 rows takes 30 seconds to update.
subq = "select id from notifications where international is null limit 250000"
update = "update notifications set international = False where id in ({})".format(subq)
result = db.session.execute(subq).fetchall()
while len(result) > 0:
db.session.execute(update)
print('commit 250000 updates at {}'.format(datetime.utcnow()))
db.session.commit()
result = db.session.execute(subq).fetchall()
# Now update notification_history
subq_history = "select id from notification_history where international is null limit 250000"
update_history = "update notification_history set international = False where id in ({})".format(subq_history)
result_history = db.session.execute(subq_history).fetchall()
while len(result_history) > 0:
db.session.execute(update_history)
print('commit 250000 updates at {}'.format(datetime.utcnow()))
db.session.commit()
result_history = db.session.execute(subq_history).fetchall()