Python炫技操作
01 直接 import
>>> import os
>>> os.getcwd()
'/home/wangbm'
import ...
import ... as ...
from ... import ...
from ... import ... as ...
02 使用 __import__
__import__(name[, globals[, locals[, fromlist[, level]]]])
参数介绍:
name (required): 被加载 module 的名称。
globals (optional): 包含全局变量的字典,该选项很少使用,采用默认值 global()。
locals (optional): 包含局部变量的字典,内部标准实现未用到该变量,采用默认值 - local()。
fromlist (Optional): 被导入的 submodule 名称。
level (Optional): 导入路径选项,Python 2 中默认为 -1,表示同时支持 absolute import 和 relative import。Python 3 中默认为 0,表示仅支持 absolute import。如果大于 0,则表示相对导入的父目录的级数,即 1 类似于 '.',2 类似于 '..'。
>>> os = __import__('os')
>>> os.getcwd()
'/home/wangbm'
>>> myos = __import__('os')
>>> myos.getcwd()
'/home/wangbm'
03 使用 importlib
>>> import importlib
>>> myos=importlib.import_module("os")
>>> myos.getcwd()
'/home/wangbm'
>>> import importlib
>>>
>>> myos = importlib.import_module("os")
>>> myos.getcwd()
'/home/wangbm'
04 使用 imp
>>> import imp
>>> file, pathname, desc = imp.find_module('os')
>>> myos = imp.load_module('sep', file, pathname, desc)
>>> myos
>>> myos.getcwd()
'/home/wangbm'
05 使用 execfile
execfile(filename[, globals[, locals]])
filename:文件名。
globals:变量作用域,全局命名空间,如果被提供,则必须是一个字典对象。
locals:变量作用域,局部命名空间,如果被提供,可以是任何映射对象。
>>> execfile("/usr/lib64/python2.7/os.py")
>>>
>>> getcwd()
'/home/wangbm'
06 使用 exec
>>> with open("/usr/lib64/python2.7/os.py", "r") as f:
... exec(f.read())
...
>>> getcwd()
'/home/wangbm'
07 import_from_github_com
$ python3 -m pip install import_from_github_com
$ python3 -m pip install --upgrade pip
import_from_github_com
>>> from github_com.zzzeek import sqlalchemy
Collecting git+https://github.com/zzzeek/sqlalchemy
Cloning https://github.com/zzzeek/sqlalchemy to /tmp/pip-acfv7t06-build
Installing collected packages: SQLAlchemy
Running setup.py install for SQLAlchemy ... done
Successfully installed SQLAlchemy-1.1.0b1.dev0
>>> locals()
{'__builtins__':
, '__spec__': None, '__package__': None, '__doc__': None, '__name__': '__main__',
'sqlalchemy':
sqlalchemy/__init__.py'>,
'__loader__':
} >>>
08 远程导入模块
# 新建一个 py 文件(my_importer.py),内容如下
import sys
import importlib
import urllib.request as urllib2
class UrlMetaFinder(importlib.abc.MetaPathFinder):
def __init__(self, baseurl):
self._baseurl = baseurl
def find_module(self, fullname, path=None):
if path is None:
baseurl = self._baseurl
else:
# 不是原定义的url就直接返回不存在
if not path.startswith(self._baseurl):
return None
baseurl = path
try:
loader = UrlMetaLoader(baseurl)
return loader
except Exception:
return None
class UrlMetaLoader(importlib.abc.SourceLoader):
def __init__(self, baseurl):
self.baseurl = baseurl
def get_code(self, fullname):
f = urllib2.urlopen(self.get_filename(fullname))
return f.read()
def get_data(self):
pass
def get_filename(self, fullname):
return self.baseurl + fullname + '.py'
def install_meta(address):
finder = UrlMetaFinder(address)
sys.meta_path.append(finder)
$ mkdir httpserver && cd httpserver
$ cat>my_info.py
name='wangbm'
print('ok')
EOF
$ cat my_info.py
name='wangbm'
print('ok')
$
$ python3 -m http.server 12800
Serving HTTP on 0.0.0.0 port 12800 (http://0.0.0.0:12800/) ...
...
一切准备好,验证开始。
>>> from my_importer import install_meta
>>> install_meta('http://localhost:12800/') # 往 sys.meta_path 注册 finder
>>> import my_info # 打印ok,说明导入成功
ok
>>> my_info.name # 验证可以取得到变量
'wangbm'
关注恋习Python,Python都好练
好文章,我在看❤️
评论