Flask配置文件管理的幾種方式:python
方法一:直接配置mysql
#!/usr/bin/env python # encoding: utf-8 from flask import Flask import time app = Flask(__name__) app.config['SEND_FILE_MAX_AGE_DEFAULT']=time.asctime() app.config['HOST']='www.aolens.cn' print app.config @app.route('/') def hello_world(): return 'Hello World! %s %s' %(app.config.get('SEND_FILE_MAX_AGE_DEFAULT'),app.config.get('HOST')) if __name__=='__main__': app.run()
能夠看到一個全局的大字典:web
<Config {'JSON_AS_ASCII': True, 'USE_X_SENDFILE': False, 'SESSION_COOKIE_PATH': None, 'SESSION_COOKIE_DOMAIN': None, 'SESSION_COOKIE_NAME': 'session', 'SESSION_REFRESH_EACH_REQUEST': True, 'LOGGER_HANDLER_POLICY': 'always', 'LOGGER_NAME': '__main__', 'DEBUG': False, 'SECRET_KEY': None, 'EXPLAIN_TEMPLATE_LOADING': False, 'MAX_CONTENT_LENGTH': None, 'APPLICATION_ROOT': None, 'SERVER_NAME': None, 'PREFERRED_URL_SCHEME': 'http', 'JSONIFY_PRETTYPRINT_REGULAR': True, 'TESTING': False, 'HOST': 'www.aolens.cn', 'PERMANENT_SESSION_LIFETIME': datetime.timedelta(31), 'PROPAGATE_EXCEPTIONS': None, 'TEMPLATES_AUTO_RELOAD': None, 'TRAP_BAD_REQUEST_ERRORS': False, 'JSON_SORT_KEYS': True, 'JSONIFY_MIMETYPE': 'application/json', 'SESSION_COOKIE_HTTPONLY': True, 'SEND_FILE_MAX_AGE_DEFAULT': 'Thu Mar 2 16:33:17 2017', 'PRESERVE_CONTEXT_ON_EXCEPTION': None, 'SESSION_COOKIE_SECURE': False, 'TRAP_HTTP_EXCEPTIONS': False}>sql
方法二:經過環境變量加載配置json
建立一個環境變量文件。config.pyflask
#內容爲鍵值,不必定要是大字典裏的 HOST=localhost POST=3306 #本身建立 export CONFIG_SET=./config.py 代碼中: app.config.from_envvar('CONFIG_SET) @app.route('/') def hello_world(): return "hello world %s %s" %(app.config.get('HOST'),app.config.get('POST'))
方法三:經過對象加載(經常使用)--from_object()vim
config對象代碼--採用了 基於類繼承的config結構,保存默認配置的Config類做爲基類,其餘類繼承之。api
建立一個文件Configlist.py瀏覽器
#!/usr/bin/env python # encoding: utf-8 class Config(): #父類能夠被下邊的類繼承到AUTHOR參數 AUTHOR='aolens' class DevelopmentConfig(Config): DEBUG = True SQL_URI='mysql://root:password@192.168.1.101/test' class ProductionConfig(Config): SQL_URI='mysql://root:password@192.168.1.101/devops' HOST='localhost' config ={ #將類寫成字典的形式存儲 'dev':DevelopmentConfig, 'pro':ProductionConfig, 'default':DevelopmentConfig }
調用Configlist.pysession
#!/usr/bin/env python # encoding: utf-8 from flask import Flask from configlist import * import time app = Flask(__name__) #對象加載,from config import * #第一種加載方式 app.config.from_object(ProductionConfig) #第二種加載方式,加載簡寫的config短也能夠加載的到 #app.config.from_object(config['pro']) print app.config @app.route('/') #/表示URL後邊+/,也可以使其餘URI,訪問就是IP+URI def hello_world(): return 'Hello World! %s %s %s' %(app.config.get('SQL_URI'),app.config.get('HOST'),app.config.get('AUTHOR')) if __name__=='__main__': app.run()
瀏覽器訪問結果:
Hello World! mysql://root:password@192.168.1.101/devops localhost aolens
如何判斷測試環境仍是生產: #!/usr/bin/env python # encoding: utf-8 from flask import Flask from config2 import * import os import time app = Flask(__name__) if os.path.exists("./pro"): app.config.from_object(config['pro']) elif os.path.exists("./dev"): app.config.from_object(DevelopmentConfig) print app.config @app.route('/TEST') def hello_world(): return 'Hello World! %s %s %s' %(app.config.get('SQL_URI'),app.config.get('HOST'),app.config.get('AUTHOR')) if __name__=='__main__': app.run()
方法四:經過配置文件--app.config.from_pyfile,config文件必須在app目錄下
vim confile.py HOST='locolhost' PORT=10000 AUTHOR='aolens' from flask import Flask app.config.from_pyfile('./confile.py') #加載配置文件 print app.config @app.route('/TEST') def hello_world(): return 'Hello World! %s %s %s' %(app.config.get('PORT'),app.config.get('HOST'),app.config.get('AUTHOR')) if __name__=='__main__': app.run()
方法五:是對方法四的一種改進 ConfigParser模塊 配置文件管理
ConfigParser簡介:
是用來讀取配置文件的包,配置文件中括號[]內包含的爲session。section下面爲相似於key-value的配置文件內容。
格式以下:
vim test.conf [api] #session port=11111 #option path=/data/api/log [web] port=1002 path=/data/web/log
使用:confile.py
import ConfigParser def getconfig(filename,section=''): cf=ConfigParser.ConfigParser() #實例化 cf.read(filename) #讀取配置文件 cf_items = dict(cf.items(section)) if cf.has_section(section) else {} #判斷SECTION是否存在,存在把數據存入字典,沒有返回空字典 return cf_items if __name__=='__main__': conf =getconfig('test.conf','web') print conf print conf['port'] print conf.get('path')
運行結果:
{'path': '/data/web/log', 'port': '1002'}
1002
/data/web/log
調用:demo.py
#!/usr/bin/env python # encoding: utf-8 from confile import getconfig from flask import Flask app = Flask(__name__) #直接配置 @app.route('/TEST') def hello_world(): conf=getconfig('test.conf','api') return 'Hello World! %s' %(conf['port']) if __name__=='__main__': app.run()
結果:
Hello World! 11111 #option