一 threading模块介绍
multiprocess模块的完全模仿了threading模块的接口,二者在使用层面,有很大的相似性
二 开启线程的两种方式
第一种
每造一个进程,默认有一个线程,就是主线程。
进程要想执行,要先造一个主线程,然后由这个进程内的线程去运行代码
from threading import Thread
import time
def task(name):
print("%s is running" % name)
time.sleep(3)
print("%s is done" % name)
if __name__ == "__main__":
# 实例化
# args 为函数传参数
t = Thread(target=task, args=("子线程1",))
# 开启子线程
t.start() # 仅仅只是给操作系统发送一个信号 与平常print没有什么区别
print("主线程")
'''
子线程1 is running
主线程
子线程1 is done
'''
上面程序开启了一个进程,两个线程,一个主线程,一个子线程。 主线程给操作系统发送信号,开启子线程
第二种
自己写一个子类去继承他
from threading import Thread
import time
# 自己写一个子类去继承他 不用默认的类
# Thread的类传进去
class MyThread(Thread):
# 重写了init方法 父类就被覆盖掉
def __init__(self, name):
# 重用父类 因为父类还有很多有用功能,继承父类
super().__init__()
self.name = name
# 方法一定要写run
def run(self):
print("%s is running" % self.name)
time.sleep(3)
print("%s is done" % self.name)
if __name__ == "__main__":
# 实例化 直接用自己自定义的类开子线程
# args 为函数传参数
t = MyThread("子线程")
#t 开启子线程
t.start() # 仅仅只是给操作系统发送一个信号 与平常print没有什么区别
# t.start() 本质是调用run方法
print("主线程")
'''
子线程 is running
主线程
子线程 is done
'''
编写一个简单的文本处理工具,具备三个任务,一个接收用户输入,一个将用户输入的内容格式化成大写,一个将格式化后的结果存入文件
'''
需求:
编写一个简单的文本处理工具,具备三个任务,一个接收用户输入,一个将用户输入的内容格式化成大写,一个将格式化后的结果存入文件
'''
import json
num = input_user = input(">>>:").strip()
num = num.upper()
with open("1.txt", "w") as f:
json.dump(num, f)