目录
Json数据格式
前言
JSON格式
python数据和Json数据的相互转化
多线程
进程和线程
串行和并行
多线程编程
创建线程参数
具体案例
网络编程
套接字
socket服务端编程步骤
socket客户端编程步骤
python操作mysql数据库
查询并接收数据
数据插入
功能:JSON就是一种在各个编程语言中流通的数据格式,负责不同编程语言中的数据传递和交互
#方式1
{"name":"admin","age":18}
#方式2
[{"name":"admin","age":18},{"name":"root","age":16},{"name":"张三","age":20}]
注意:json数据相对与python就是字典或者字典列表
#导入json模块
import json
#准备符合格式json格式要求的python数据
data=[{"name":"老王","age":16},{"name":"张三","age":20}]
#通过json.dumps(data)方法把python数据转化为json数据
#ensure_ascii参数改为False表示不使用ASCII码来转换他,而是把内容直接输出出去
data=json.dumps(data,ensure_ascii=False)
#通过json.loads(data)方法把json数据转化为python数据
data=json.loads(data)
进程:就是一个程序,运行在系统之上,那么便称这个程序为一个运行进程,并分配ID方便系统管理
线程:线程归于进程,一个进程可开启多个线程执行不同工作,线程是进程的实际工作最小单位
注意
#导入线程模块
import threading
#创建线程
thread_obj=threading.thread([group],target,[name],[args],[kwargs])
#启动线程
thread_obj.start()
import threading
import time
def sing(msg):
while True:
print(msg)
time.sleep(1)
def dance(email):
while True:
print(email)
time.sleep(1)
if __name__ == '__main__':
#因为target是第二个参数,所以必须给参数名进行传参
sing_thread=threading.Thread(target=sing,args=("我在唱歌……",))
dance_thread=threading.Thread(target=dance,kwargs={"email":"我在跳舞"})
#启动线程
sing_thread.start()
dance_thread.start()
socket:简称套接字,其是进程间通信的一个工具,好比现实生活中的插座,所有的家用电器想要工作都是基于插座进行,进程之间想要进行网络通信需要socket
两进程之间通过socket进行通信就必须有服务端和客户端
#socket服务端开发
#导入socket模块
import socket
#创建socket对象
socket_server=socket.socket()
#绑定ip和端口(里面传的是__address的元组)
socket_server.bind(("localhost",8888))
#监听端口(里面的1表示允许客户端连接的数量)
socket_server.listen(1)
#等待客户端的连接
#accept为阻塞方法若没有连接则将会卡在这里不执行
#这里返回的result为二元元组
result:tuple=socket_server.accept()
conn=result[0] #客户端和服务端的连接对象
address=result[1] #客户端的地址信息
print(f"接收到了客户端的连接,客户端的信息是:{address}")
while True:
#接收客户端发送的信息,使用客户端和服务端的本次连接对象而非socket_server
data:str=conn.recv(1024).decode("UTF-8")
#recv也是阻塞方法,其接收参数为缓冲区大小,一般1024即可
#recv方法的返回值为一个字节数组,不是字符串,所以可以通过decode方法通过UTF-8编码转换为字符串对象
print(f"客户端发送的消息为:{data}")
#发送回复消息
msg=input("请输入你要和客户端回复的消息:")
if msg=="exit":
break
conn.send(msg.encode("UTF-8"))
#关闭连接
conn.close()
socket_server.close()
#socket客户端开发
#导入socket模块
import socket
#创建socket对象
socket_client=socket.socket()
#连接到服务端(里面传的是__address的元组)
socket_client.connect(("localhost",8888))
while True:
#向服务端发送消息
msg=input("请输入要给服务端发送的消息:")
if msg=="exit":
break
socket_client.send(msg.encode("UTF-8"))
#接收返回的消息
#recv方法为阻塞方法,传入参数为字节缓冲区大小
data=socket_client.recv(1024).decode("UTF-8")
print(f"服务端发来的消息为:{data}")
#关闭连接
socket_client.close()
前言:在python中,使用第三方库pymysql来完成对mysql数据库的操作
安装:pip install pymysql
#导入connection模块
from pymysql import Connection
#获取mysql数据库的链接对象
conn=Connection(
host='localhost', #主机名
port=3306, #端口号
user='root', #用户名
password='root' #密码
)
#打印mysql数据库的软件信息
print(conn.get_server_info())
#获取游标对象
cursor=conn.cursor()
#选择数据库
conn.select_db("test")
#使用游标执行sql语句
cursor.execute("select * from user")
#接收查询结果
result:tuple=cursor.fetchall()
print(result)#((1, 'lili'), (2, 'lan'))
#对查询结果遍历
for i in result:
print(i)
#关闭数据库链接
conn.close()
#导入connection模块
from pymysql import Connection
#获取mysql数据库的链接对象
conn=Connection(
host='localhost', #主机名
port=3306, #端口号
user='root', #用户名
password='root' #密码
)
#打印mysql数据库的软件信息
print(conn.get_server_info())
#获取游标对象
cursor=conn.cursor()
#选择数据库
conn.select_db("test")
#使用游标执行sql语句
cursor.execute("insert into user values(3,'kate')")
#确认
conn.commit()
#conn.rollback()#回滚
#关闭数据库链接
conn.close()
注意:在数据插入时必须提交才能成功。