Python-Flask-открыть веб-страницу в браузере по умолчанию

Я работаю над небольшим проектом в Python. Она разделена на две части.

первая часть отвечает за обход интернета и извлечение некоторой информации и вставку их в базу данных.

вторая часть отвечает за представление этой информации с использованием базы данных. Обе части имеют общую базу данных. Во второй части я использую фреймворк Flask для отображения информации в виде html с некоторым форматированием, стилем и т. д. чтобы это выглядело уборщик.

исходные файлы обеих частей находятся в одном пакете, но для правильного запуска этой программы пользователь должен запустить crawler и results presenter отдельно:

python crawler.py

а то

python presenter.py

все в порядке, кроме одной вещи. Что мне нужно сделать, так это создать результат в формате html и открыть страницу с результатами в браузере пользователя по умолчанию, но он всегда открывается дважды, вероятно, из-за наличия метода run (), который запускает колбу в новом потоке, и для меня все становится облачным. Я не знаю, что мне делать, чтобы быть в состоянии presenter.py открыть только одну вкладку/Окно после запуска.

вот фрагмент моего кода :

from flask import Flask, render_template
import os
import sqlite3


# configuration
DEBUG = True
DATABASE = os.getcwd() + '/database/database.db'

app = Flask(__name__)
app.config.from_object(__name__)
app.config.from_envvar('CRAWLER_SETTINGS', silent=True)



def connect_db():
    """Returns a new connection to the database."""
    try:      
        conn = sqlite3.connect(app.config['DATABASE'])
    return conn
except sqlite3.Error:
    print 'Unable to connect to the database'
    return False


@app.route('/')
def show_entries():
    u"""Loads pages information and emails from the database and
    inserts results into show_entires template. If there is a database
    problem returns error page.
    """
    conn = connect_db()


    if conn:        
    try:            
        cur = connect_db().cursor()

        results = cur.execute('SELECT url, title, doctype, pagesize FROM pages')    
        pages = [dict(url=row[0], title=row[1].encode('utf-8'), pageType=row[2], pageSize=row[3]) for row in results.fetchall()]   


        results = cur.execute('SELECT url, email from emails')
        emails = {}


        for row in results.fetchall():                
            emails.setdefault(row[0], []).append(row[1])                

        return render_template('show_entries.html', pages=pages, emails=emails)

    except sqlite3.Error, e:
        print ' Exception message %s ' % e
        print 'Could not load data from the database!'
        return render_template('show_error_page.html')


else:
    return render_template('show_error_page.html')        


if __name__ == '__main__':
    url = 'http://127.0.0.1:5000'
    webbrowser.open_new(url)
    app.run()

1 ответов


Я использую аналогичный код на Mac OS X (с браузерами Safari, Firefox и Chrome) все время, и он работает нормально. Предполагая, что вы можете столкнуться с функцией автоматической перезагрузки Flask. Set debug=False и он не будет пытаться автоперезагрузкой.

другие предложения, основанные на моем опыте:

  • рассмотрите рандомизацию используемого порта, так как циклы быстрого редактирования-запуска-тестирования иногда обнаруживают, что порт 5000 ОС все еще используется. (Или, если вы запускаете код несколько раз одновременно, скажите случайно порт действительно до сих пор используется.)
  • дайте приложению короткое время, чтобы развернуться, прежде чем начать запрос браузера. Я делаю это путем вызова threading.Timer.

вот мой код:

import random, threading, webbrowser

port = 5000 + random.randint(0, 999)
url = "http://127.0.0.1:{0}".format(port)

threading.Timer(1.25, lambda: webbrowser.open(url) ).start()

app.run(port=port, debug=False)

(Это все под if __name__ == '__main__':, или в отдельной функции "start app", если хотите.)