时间:2021-05-23
I/O
with语句
with context_expression [as target(s)]: with-bodycontext_expression返回值遵从上下文管理协议,包含__enter__()与__exit__()方法,as语句的target(s)得到的是__enter__()返回值,执行with-body后会调用上下文管理器的__exit__()方法,使用with语句,可以减轻某些代码编写负担,比如文件读写。
读文件
open()方法打开文件模式,默认以utf8格式读取,添加后缀'b'(rb、wb)表示以二进制方式读取,mode有以下几种:
StringIO和BytesIO
StringIO将string按照文件的方式读取和写入,BytesIO将bytes按照文件的的方式读取和写入。
OS
通过OS模块,与操作系统信息交互,如创建、移动、列出文件等等。
序列化
通过内置模块pickle,实现序列化与反序列化,使用json模块完成JSON数据的序列化和反序列化。
import pickled = dict(name = 'sha', age = 26)# 将序列化内容写入文件with open('dump', 'wb') as f: pickle.dump(d, f)# 从文件中读取序列化内容with open('dump', 'rb') as f: d = pickle.load(f)print(d) # {'name': 'sha', 'age': 26}进程与线程
进程
Python调用一次进程fork()会有两次返回,子进程永远返回0,父进程中返回子进程ID。os.fork()不支持windows,multiprocessing模块是跨平台版本的多进程模块。
import ospid = os.fork() # pid后的代码会在两个进程中分别执行,通过pid值不同判断父子if pid == 0: print('exec in child process')else: print('exec in parent process')# exec in parent process# exec in child process进程池
from multiprocessing import Pooldef say(x): print(x)if __name__ == '__main__': p = Pool(4) for i in range(5): p.apply_async(say, args=(i,)) p.close() p.join()子进程
import subprocessprint('$ nslookup amsimple.com')r = subprocess.call(['nslookup', 'amsimple.com'])print('Exit code:', r)进程间通信
进程间通信通过Queue与Pipes实现,父进程创建Queue传递给子进程。
线程
Python提供两个模块_thread与threading,前者是低级模块后者是高级模块,对_thread进行了封装。
启动一个线程就是把一个函数传入并创建Thread实例,然后调用start()开始执行:
import threading# 新线程执行的代码:def say(): print('%s say hello' % threading.current_thread().name)t = threading.Thread(target=say, name = 'SayThread')t.start()t.join()threading.current_thread()返回但前运行线程的实例,主线程名MainTreed,子线程名在创建时指定。
通过threading.Lock()获取锁,某些需要线程安全的操作,先通过acquire()获取锁,通过release()释放锁。
Python中的线程因为GIL锁,无法真正利用多核。
通过ThreadLocal实现线程级的全局变量,不同线程间相互不影响。
import threadingth_local = threading.local() # th_local会跟线程绑定,不同线程看到的是不同对象分布式进程
managers模块依靠网络通信,可以把多进程分布到多台机器上。
正则
通过'r'前缀定义正则字符串,通过re模块做正则匹配等操作。
import res = r'^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$'re.match(s, 'shasharoman@gmail.com')总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
电压详细分布讲解 +12V主要是给CPU供电,通过电压调整模块,调节成1.15-1.75V核心电压,供CPU、VttFSB、CPU-I/O。+12V除了C
以电脑为例,io接口位于总线和I/O设备之间,I/O接口的功能是负责实现CPU通过系统总线把I/O电路和外围设备联系在一起。 I/O输入/输出(Input/O
RabbitMQ消息队列PYthreadingQueue进程Queue父进程与子进程,或同一父进程下的多个子进程进行交互缺点:两个不同Python文件不能通过上
本文实例讲述了Python简单I/O操作。分享给大家供大家参考,具体如下:文件:poem='''helloworld'''f=file('book.txt','
概述I/O操作不仅包括屏幕输入输出,还包括文件的读取与写入,Python提供了很多必要的方法和功能,进行文件及文件夹的相关操作。本文主要通过两个简单的小例子,简