python 小知识点

2022-12-19  本文已影响0人  懒生活

50个基本的python命令

01 导入模块

import XXXXX
import XXXXX as xm
from XXXXX import * 

上面三个常用的导入句式, 前两句是把模块连带命名空间导入. 要访问模块的时候,还需要使用模块名称. from句式可以理解为把模块里面的相关代码直接拷贝到当前文件中了,此时导入的模块内部函数,跟本文件内的内部函数一样直接调用.

02 reload 重新加载模块

这个命令的使用场景如下, 在交互界面下, 你之前已经加载过某个模块了import XXXXXX, 因为某种原因你使用外部编译器修改调整了这个模块XXXXXX, 但在交互界面下,你是没有办法继续通过命令import XXXXXX来重新加载你修改的内容的. 此时需要XXXXXX.reload(). 模块里面的所有变量赋值因为reload会被更新. 但是如果你修改的内容包括删除一个变量, 那么即使reload模块,这个变量因为之前存在,还会继续存在

03 pip install命令

04 执行脚本exec("python expressions")

[[python3] exec()函数 - 简书 (jianshu.com)](https://www.jianshu.com/p/5caf0415214b)

05 ipython

06 eval()函数

07 map函数

def addition(n):
    return n + n
numbers = (1, 2, 3, 4)
result = map(addition, numbers)
print(list(result))

map函数返回的是map对象,可以通过list转换成列表.

08 filter函数

filter函数和map函数都是对原有的序列应用规则,产生新的序列. 入参的顺序都是规则+操作序列

09 staticmethod

类似于c++类里面定义的静态函数,这个函数的调用不需要类的实例化.

class Maths():
    @staticmethod
    def addNum(num1, num2):
        return num1 + num2
# Driver's code
if __name__ == "__main__":
    # Calling method of class
    # without creating instance
    res = Maths.addNum(1, 2)
    print("The result is", res)

10 iter()函数

首先要弄明白可迭代和迭代器的含义. 迭代器是一个可以记住已遍历位置的对象, 迭代器只往前, 遍历到达末尾后会抛出异常. 对于可迭代的容器使用 for xx in container: 语句时, 本质上for语句会对container作用iter()函数,生成这个容器的迭代器,然后内部使用next依次遍历,并且检测到异常后退出遍历. iter函数最有用的用法如下

with open("bigFile.txt") as fp:
    for line in iter(fp.readline, ''):
        process_line(line)

对于一个超大的文件,如果你调用lines = fp.readlines(), 那么这时候所有的行都会存放在lines列表中,这样对内存的消耗是比较大的.但是如果使用for line in iter(fp.readline,''):语句,那么for循环中,每次都会调用一次fp.readline. 得到值赋给line, 一直循环直到readline读取到空字符为止. 这样的惰性计算处理,使得内存的使用得到了优化. 而类似下面的应用,感觉就没有什么意义了:

a = [1,2,3,4,5]
for i in iter(a):
    print(i)

每次执行iter(a)的时候,会读取a中的一个元素,并赋值给i. 此时所有的数据已经在a容器里面,改占用的内存已经被占用了.不如下面的写法来得直接

a = [1,2,3,4,5]
for i in a:
    print(i)

11 sorted(listA)函数

a=[1,2,5,3,4]
print(sorted(a))

注意sorted默认从小到大进行排序, 而且sorted不是在入参a上进行排序,而是生成一个新的列表. 旧的列表a是没有变化的.

12 yield

带有yield的函数定义,返回的是一个迭代器. yield相当于return, 下一次迭代的时候,会从上一个yield的后一行进行执行.

def testYield():
    yield 1
    yield 2
    yield 3
    yield 4
    yield 5
res=testYield()
for item in res:
    print(item)

13 shelving data 序列化任意对象

可以通过shelving把任意python对象序列化存储到文件中,可以认为shelve类似于一个key-value数据库.
flag='c'表示如果数据库文件不在,就创建.

import shelve
d = shelve.open('my.db', flag = 'c')
d['abc'] =['a','b']
d.close()

os.environ

os.environ可以设定和查询环境变量
设定环境变量如下['CUDA_VISIBLE_DEVICES'] = "0,1"
查询环境变量如下
os.environ.get('CUDA_VISIBLE_DEVICES')

name的作用

一个py文件会绑定一个自己的name变量。如果这个py文件是被直接运行的,这个变量会被解释器赋值为“main”,如果是被import进来的,会被赋值为文件名。

遍历出说明满足条件的目录

f = glob.glob(r"/home//.py")

快捷的获取一个全路径下的文件名称

os.path.basename("/home/test/a.txt")
可以直接得到a.txt 如果路径是纯文件夹,没有文件名,那返回的是空。

python中的变量实质

(https://blog.csdn.net/qq_37891604/article/details/124528827)

上一篇 下一篇

猜你喜欢

热点阅读