python用法查询笔记_Python笔记8:模块操作

mudule代表模块,IDLE可以测试和编辑Python,但是保存还是要靠文件的,我用的IDEA,同一场上也有专门用于Python开发的IDE,和IDEA差不多,所以就不重复下载了

深入了解Modules

用IDE的好处

最大的好处就是可以提示

代码提示:尤其对我们新手来说,太爽了

警告提示: Python对格式要求相对严格,格式不符合规范也会给黄色警告,这时候看你自己了,可以忽略,也可以修改

报错提示:写错了,会直接飘红报错,IDLE就不会

导入python sdk,然后创建一个test类

# 输出斐波那契数列

def fib(n):

a, b = 0, 1

while b < n:

print(b, end=' ')

a, b = b, a + b

print()

# 输出斐波那契数组

def fib2(n):

result = []

a, b = 0, 1

while b < n:

result.append(b)

a, b = b, a + b

return result

模块技巧

IDEA是一个很好的集成环境,常用的语言都可以支持,自带命令行调用工具

进入文件所在目录后,进入python编辑模式

文件名.函数名

# 导包

>>> import test5

# 测试方法

>>> test5.fib(100)

1 1 2 3 5 8 13 21 34 55 89

>>> test5.fib2(100)

[1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89]

# 赋值本地函数

>>> fib = test5.fib2(100)

>>> fib

[1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89]

直接导入函数名

直接导入文件中具体的函数,前提是导包的时候直接导入具体函数名,如果一个文件很大,为了避免冗余,也可以只选择导入具体函数,可以导入多个函数

可以选择通配符 * 表示所有函数。但不推荐使用这种方式,在交互式编程中,用来保存类型还可以,在正式项目中,会导致可读性变差,还可能隐藏了一些已经定义好的东西,所以还是尽量用具体的函数吧。

>>> from test5 import fib,fib2

>>> fib(100)

1 1 2 3 5 8 13 21 34 55 89

>>> fib2(100)

[1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89]

# 通配符 *

>>> from test5 import *

>>> fib(500)

1 1 2 3 5 8 13 21 34 55 89 144 233 377

像脚本一样执行模块

根路径下:

python 文件名 参数

例如刚才的文件,现在加一个main函数进行输出

# 输出斐波那契数列

def fib(n):

a, b = 0, 1

while b < n:

print(b, end=' ')

a, b = b, a + b

print()

# 输出斐波那契数组

def fib2(n):

result = []

a, b = 0, 1

while b < n:

result.append(b)

a, b = b, a + b

return result

# main函数

if __name__ == '__main__':

import sys

num = int(sys.argv[1])

if num >= 50:

fib(num)

else:

print(fib2(num))

结果

文件目录>python test5.py 50

1 1 2 3 5 8 13 21 34

文件目录>python test5.py 40

[1, 1, 2, 3, 5, 8, 13, 21, 34]

这种方式是交互式的,所以直接运行不会有输出,还有一种方法是有输出结果的,直接运行文件即可,格式为python 文件名

from functools import reduce

if __name__ == '__main__':

# 一行代码实现对列表a中的偶数位置的元素进行加3后求和?

a = [1, 2, 3, 4, 5]

print(reduce(lambda x, y: x + y, [a[x] + (x + 1) % 2 * 3 for x in range(0, 5)]))

# 输出结果

文件目录>python test1.py

24

模块搜索路径

当导入spam的模块时,解释器首先搜索带有该名称的内置模块。如果没有找到,它会在变量sys.path提供的目录列表中搜索一个名为spam.py的文件。

sys.path从这些位置初始化:

包含输入脚本的目录(或没有指定文件的当前目录)。

PYTHON_PATH(环境变量中设置的地址,与shell变量PATH的语法相同)。

默认安装地址

在初始化之后,Python程序可以修改sys.path。

包含运行脚本的目录被放置在搜索路径的开头,在标准库路径前面。这意味着该目录中的脚本将被加载,而不是库目录中相同名称的模块。

标准模块库

Python附带了一个内置的标准模块库,这些服务提供了不属于该语言核心部分的操作,但仍然是内置的,无论是为了效率还是为了提供对操作系统原语(如系统调用)的访问。这些模块的集合是一个配置选项,它也依赖于底层平台。

如果用交互模式,可以尝试定义一下下面两个变量。

# 虽然是内置的,但是不导包还是会报错

>>> sys.ps1

Traceback (most recent call last):

File "", line 1, in

NameError: name 'sys' is not defined

# 导包后具体看一下

>>> import sys

>>> sys.ps1

'>>> '

>>> sys.ps2

'... '

# 并且他们是可以改变的

>>> sys.ps1 = "what the fuck>"

what the fuck>print("hello!")

hello!

变量sys.path是一个字符串列表,它决定了解释器的模块搜索路径。它从环境变量中被初始化到默认路径,如果没有设置环境变量,就从内置的默认路径中初始化。

dir()函数

内置的函数dir()用于查找模块定义的名称。返回一个已排序的模块列表

>>> import test1,test5,sys

# test1中的模块,注意,有很多内置的

>>> dir(test1)

['__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__',

'__package__', '__spec__', 'reduce']

# test5中的模块

>>> dir(test5)

['__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__',

'__package__', '__spec__', 'fib', 'fib2']

# sys中的模块

>>> dir(sys)

['__displayhook__', '__doc__', '__excepthook__', '__interactivehook__', '__loade

r__', '__name__', '__package__', '__spec__', '__stderr__', '__stdin__', '__stdou

t__', '_clear_type_cache', '_current_frames', '_debugmallocstats', '_enablelegac

ywindowsfsencoding', '_getframe', '_git', '_home', '_xoptions', 'api_version', '

argv', 'base_exec_prefix', 'base_prefix', 'builtin_module_names', 'byteorder', '

call_tracing', 'callstats', 'copyright', 'displayhook', 'dllhandle', 'dont_write

_bytecode', 'exc_info', 'excepthook', 'exec_prefix', 'executable', 'exit', 'flag

s', 'float_info', 'float_repr_style', 'get_asyncgen_hooks', 'get_coroutine_wrapp

er', 'getallocatedblocks', 'getcheckinterval', 'getdefaultencoding', 'getfilesys

temencodeerrors', 'getfilesystemencoding', 'getprofile', 'getrecursionlimit', 'g

etrefcount', 'getsizeof', 'getswitchinterval', 'gettrace', 'getwindowsversion',

'hash_info', 'hexversion', 'implementation', 'int_info', 'intern', 'is_finalizin

g', 'last_traceback', 'last_type', 'last_value', 'maxsize', 'maxunicode', 'meta_

path', 'modules', 'path', 'path_hooks', 'path_importer_cache', 'platform', 'pref

ix', 'ps1', 'ps2', 'set_asyncgen_hooks', 'set_coroutine_wrapper', 'setcheckinter

val', 'setprofile', 'setrecursionlimit', 'setswitchinterval', 'settrace', 'stder

r', 'stdin', 'stdout', 'thread_info', 'version', 'version_info', 'warnoptions',

'winver']

# 如果没有参数,dir()会打印出当前定义的名称

>>> dir()

['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__pack

age__', '__spec__', 'sys', 'test1', 'test5']

dir()并不会列出内置函数和变量的名称。如果想列出来就用builtins作为参数试试吧

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值