XiaoKL

Python.tornado.2.tornado.options

记录Tornado-4.0.2源码的阅读,学习,分析

options.py

1. imports 部分

1.1 __future__

1 from __future__ import absolute_import, division, print_function, with_statement

future_statement 即:from __futuren import XXX. 参见 XiaoKL学Python(C)__future__

1.2 other imports from Python Library

1 import datetime
2 import numbers
3 import re
4 import sys
5 import os
6 import textwrap

1.3 other imports from tornado

1 from tornado.escape import _unicode
2 from tornado.log import define_logging_options
3 from tornado import stack_context
4 from tornado.util import basestring_type, exec_in

 

2. 定义的类

2.1 OptionParser类 

该类负责解析命令行的Option, 每个option被抽象为类_Option的对象。

2.2 _Option类

代表命令行上的每个option,该类为内部类。

2.3 全局的OptionParser对象

定义了一个全局的OptionParser对象。options.py提供的接口都是在该对象上进行操作的。

末尾调用了以下接口来将log相关的option添加到options.py模块中。

1 define_logging_options(options)

3. options.py对外提供的接口

[Todo]

3.1 define

1 def define(name, default=None, type=None, help=None, metavar=None,
2            multiple=False, group=None, callback=None)

 

3.2 parse_command_line

1 def parse_config_file(path, final=True)

 

 


Learn From options.py

1. sys模块

import sys

https://docs.python.org/2/library/sys.html?highlight=sys#module-sys

sys._getframe([depth])

"Return a frame object from the call stack. If optional integer depth is given, return the frame

object that many calls below the top of the stack. If that is deeper than the call stack, ValueError 

is raised. The default fordepth is zero, returning the frame at the top of the call stack."

在options.py中的使用,在OptionParser类的define方法的实现中:

1         frame = sys._getframe(0)

  

2. inspect 模块

https://docs.python.org/2/library/inspect.html

"The inspect module provides several useful functions to help get information about live

objects such as modules, classes, methods, functions, tracebacks, frame objects, and code objects. "

该模块中包含 frame 类型(即: sys._getframe() 返回值的类型 )的说明。

 

3. unittest.mock.patch

mock 模块

Python中的单元测试。

4. 不了解的语法

4.1 return xxxx if yyyy else zzzz  

1     def value(self):
2         return self.default if self._value is _Option.UNSET else self._value

 4.2 xxx for yyy, zzz in ttt

1     _TIMEDELTA_ABBREV_DICT = dict(
2         (abbrev, full) for full, abbrevs in _TIMEDELTA_ABBREVS
3         for abbrev in abbrevs)

4.3 正则表达式

1     _FLOAT_PATTERN = r'[-+]?(?:\d+(?:\.\d*)?|\.\d+)(?:[eE][-+]?\d+)?'

 

 


 

Reference

1. http://www.tornadoweb.org/en/stable/options.html

posted on 2015-04-23 16:18  XiaoKL  阅读(538)  评论(0编辑  收藏  举报

导航