十五. Python基础(15)--内置函数-1
1 ● eval(), exec(), compile()
执行字符串数据类型的python代码 ① eval : 有返回值, 适用于执行计算语句, 例如eval("4+3"). ② exec : 没有返回值, 适用于执行流程控制语句, 例如exec(a = b if b>c else c) ③ complie: code1 = 'for i in range(0,3): print(i)' compile1 = compile(code1, '', 'exec') # 中间表示filename的参数即使没有也要有一个空字符串(其实也可以胡乱写一个字符串) print(compile1) # <code object <module> at 0x0000000002802270, file "", line 1> exec(compile1) exec(compile1) ''' 0 1 2 0 1 2 ''' |
compile(str ,filename ,kind ) compile()将一个字符串编译为字节代码, str是将要被编译的字符串, filename是定义该字符串变量的文件, kind参数指定了代码被编译的类型: eval, single, exec 'eval'指一个表达式. 'single'指单个语句, 'exec'指多个语句, 返回一个代码对象,该对象也可以被传递给eval()函数和exec语句来执行
预编译, 可以有效提高程序的执行效率 |
eval(), exec()和compile()不要随便使用, 若使用, 也要做好充分的测试. |
2 ● print()函数扩展
print(*objects, sep=' ', end='\n', file=sys.stdout, flush=False) |
print("枯藤", "老树", "昏鸦", sep = ",", end = "←") # 枯藤,老树,昏鸦← # sep默认为一个空格" ", end默认为一个换行符 |
import time for i in range(0,101,10): time.sleep(1) # 便于观察 char_num = i//2 #打印多少个'*' #per_str = '\r%d%% : %s\n' % (i, '*' * char_num) if i == 100 else '\r%d%% : %s'%(i,'*'*char_num) # 等价于: #per_str = '\r%d%% : %s' % (i, '*' * char_num) if i != 100 else '\r%d%% : %s\n' % (i, '*' * char_num) # 或者是: per_str = '\r%d%% : %s' % (i, '*' * char_num) # 但不能是: print(per_str,end='', flush=True)
# 100% : ************************************************** # 每次循环都是从头开始打印在控制台上的 |
f = open('print_test', 'a', encoding = 'utf-8') print("This is a log!", file = f) # 用print写日志文件. |
3 ● 有关换行(line feed), 回车(carriage)
\r--CR(carriage return, 回车)--把光标移到所在行开头 \n--LF(line feed, 换行)--把光标移到下一行开头。 \r\n—CR+LF—回车+换行 |
4 ● 有关内置函数hash()
url = 'https://www.baidu.com/' from urllib.request import urlopen content = urlopen(url).read() dic = {hash(url):content} for key in dic: print(key) print(hash(url)) ''' 4122514777272343416 4122514777272343416 # 在运行一次, 得到: 8389699687043686450 8389699687043686450 ''' # ※在python的一次执行中, 对于相同的可hash的对象, hash()函数返回的都是相同的数字(因为对象在一个生命周期内) |
5 ● filter()函数和map()函数
# filter()函数, 类似于列表推导式 def func1(n): if n % 2 == 0: return True li = [3,2,6,9,8]
print(filter(func1, li)) # filter()方法返回一个迭代器 print(list(filter(func1, li)))
''' <filter object at 0x00000000025E99B0> [2, 6, 8] ''' |
def func2(n): if n % 2 == 0: return n li2 = [3,2,6,9,8]
print(list(map(func2, li2))) ''' [None, 2, 6, None, 8] '''
def func3(n): return n**2
print(list(map(func3, li2))) ''' [9, 4, 36, 81, 64] ''' |
典型案例: 删除 None 或者空字符串 |
# def deter(m): # if m and len(m.strip()) > 0: # 注意m必须写在len(m.strip()) > 0之前, 否则会被警示None无法计算长度 # return True
# 等价于: def deter(m): return m and len(m.strip())
lst = ['test', None, '', 'str', ' ', 'END']
print(list(filter(deter, lst))) ''' ['test', 'str', 'END'] |
6 ● 内置函数__import__()
__import__('a') # 导入 a.py 模块 |