python进程管理教程(Python I/O与进程的详细讲解)
python进程管理教程
Python I/O与进程的详细讲解I/O
with语句
|
with context_expression [as target(s)]: with - body |
context_expression
返回值遵从上下文管理协议,包含__enter__()
与__exit__()
方法,as语句的target(s)得到的是__enter__()返回值,执行with-body
后会调用上下文管理器的__exit__()方法,使用with语句,可以减轻某些代码编写负担,比如文件读写。
读文件
|
try : f = open ( '/path/to/file' , 'r' , encoding = 'utf8' , errors = 'ignore' ) print (f.read( 1024 )) finally : if f: f.close() # 使用with语句 with open ( '/path/to/file' , 'r' ) as f: print (f.read( 1024 )) |
open()
方法打开文件模式,默认以utf8格式读取,添加后缀'b'(rb、wb)表示以二进制方式读取,mode有以下几种:
StringIO和BytesIO
StringIO将string按照文件的方式读取和写入,BytesIO将bytes按照文件的的方式读取和写入。
OS
通过OS模块,与操作系统信息交互,如创建、移动、列出文件等等。
序列化
通过内置模块pickle,实现序列化与反序列化,使用json模块完成JSON数据的序列化和反序列化。
|
import pickle d = 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 os pid = 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 Pool def 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 subprocess print ( '$ 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 threading th_local = threading.local() # th_local会跟线程绑定,不同线程看到的是不同对象 |
分布式进程
managers模块依靠网络通信,可以把多进程分布到多台机器上。
正则
通过'r'前缀定义正则字符串,通过re模块做正则匹配等操作。
|
import re s = r '^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$' re.match(s, 'shasharoman@gmail.com' ) |
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对开心学习网的支持。如果你想了解更多相关内容请查看下面相关链接
原文链接:https://amsimple.com/blog/article/43.html
- python改变字体颜色指令(使用Python自动化破解自定义字体混淆信息的方法实例)
- python爬微信好友(python抓取需要扫微信登陆页面)
- python直接查询mongodb(pymongo中聚合查询的使用方法)
- python调用excel教程(利用python在excel里面直接使用sql函数的方法)
- python协程详解(为什么你还不懂得怎么使用Python协程)
- pythonmysql使用教程(Python异步操作MySQL示例使用aiomysql)
- python元组汇总(Python数据类型之Tuple元组实例详解)
- python 串口图形化(python使用MQTT给硬件传输图片的实现方法)
- python网页自动化selenium(python利用selenium进行浏览器爬虫)
- python实现列表删除重复元素(Python代码实现删除一个list里面重复元素的方法)
- 抖音上很火的表白程序链接(我喜欢你 抖音表白程序python版)
- python中怎么实现登录程序(详解Python用户登录接口的方法)
- python 配置文件环境变量(python环境路径配置以及命令行运行脚本)
- python操作json格式(详解python 3.6 安装json 模块simplejson)
- python3语法规则(Python3解释器知识点总结)
- 微信小程序企业微信打卡(使用Python实现企业微信的自动打卡功能)
- 美国数十万加仑牛奶倒入下水道,贫民区食不果腹,历史再次重演(美国数十万加仑牛奶倒入下水道)
- 美国倒掉数十万加仑牛奶 上热搜第一,这一幕似曾相识(美国倒掉数十万加仑牛奶)
- 深度 倒牛奶 这一幕为何又在美国上演(深度倒牛奶)
- 美国数十万加仑牛奶倒下水道怎么回事 原因曝光令人心痛(美国数十万加仑牛奶倒下水道怎么回事)
- 探索中国神秘文字(探索中国神秘文字)
- 重温《蜗居》 宋思明选中海藻为红颜知己,纯属巧合,与爱无关(宋思明选中海藻为红颜知己)
热门推荐
- mysql数据库延时监控(Mysql sql慢查询监控脚本代码实例)
- python opencv图像合并(Python3+OpenCV2实现图像的几何变换平移、镜像、缩放、旋转、仿射)
- nginx 怎么搭建web服务器(Linux+Nginx+Php架设高性能WEB服务器)
- jquery属性选择器
- C#常用的命名规范
- php运用redis实现抢购实例(PHP+redis实现微博的拉模型案例详解)
- python函数大全详细(详解Python函数式编程—高阶函数)
- zabbix如何监控web(Zabbix 结合 bat 脚本实现多个应用程序状态监控的方法)
- php网站经典案例(PHP生成短网址的思路以及实现方法的详解)
- dedecms中的有些功能如何修改(Dedecms 生成速度慢 的解决办法)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9