Python网络编程常用代码
服务器端代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
# -*- coding: cp936 -*- import socket sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) #初始化socket sock.bind(( "127.0.0.1" , 8001 )) #绑定本机地址,8001端口 sock.listen( 5 ) #等待客户连接 while True : print "waiting client connection..." connection,address = sock.accept() #接收客户连接请求 print "a client have connected..." while True : try : connection.settimeout( 5 ) #设置超时时间 buf = connection.recv( 1024 ) #接收数据 if buf = = "1" : connection.send( "you have send me 1!welcome to server!" ) elif buf = = "2" : connection.send( "you have send me 2!I have recv!" ) elif buf = = "3" : connection.send( "close the connection!" ) break else : connection.send( "unknow command!" ) except socket.timeout: print "time out" connection.close() print "a client exit..." |
客户器端代码:
1
2
3
4
5
6
7
8
9
10
11
12
|
import socket sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) sock.connect(( "127.0.0.1" , 8001 )) import time time.sleep( 2 ) while True : data = raw_input ( "input command:" ); sock.send(data) print sock.recv( 1024 ) if data = = "3" : break sock.close() |
1.首先开两个IDLE,分别打开服务器端和客户器端代码。
2.F5运行服务器端代码,会出现waiting client connection...
3.F5运行客户端代码,会出现input command: ;
4.这时服务器和客户端就连接上了,可以正常的通信啦,如图:
5.再次运行服务器端代码时会出现错误,这时可以通过任务管理器,将其中的pythonw.exe进程结束,重新打开,编译就可以啦!
客户端:
1
2
3
4
5
6
|
import socket s = socket.socket() host = socket.gethostname() port = 1234 s.connect((host, port)) print s.recv( 1024 ) |
服务端:
1
2
3
4
5
6
7
8
9
10
11
12
|
import socket s = socket.socket() host = socket.gethostname() port = 1234 s.bind((host, port)) s.listen( 5 ) while True : c, addr = s.accept() print 'Got connection from' , addr c.send( 'Thank you for connecting' ) c.close() |
http编程
1
2
|
from urllib import urlopen |
加上正规表达式
1
2
3
4
|
import re text = webpage.read() m = re.search( '<a href="([^"]+)" .*?>about</a>' , text, re.IGNORECASE) m.group( 1 ) |
urllib
urllib2
一个基于SocketServer的小型服务器例子:
1
2
3
4
5
6
7
8
9
|
from SocketServer import TCPServer, StreamRequestHandler >>> class Handler(StreamRequestHandler): def handle( self ): addr = self .request.getpeername() print 'Got connection from' , addr self .wfile.write( 'Thank you for connecting' ) >>> server = TCPServer(('', 1234 ), Handler) >>> server.serve_forever() |
使用SocketServer进行分叉和线程处理
分叉Server:
1
2
3
4
5
6
7
8
9
|
from SocketServer import TCPServer,ForkingMinIn, StreamRequestHandler class Server(ForkingMinIn, TCPServer): pass class Handler(StreamRequestHandler): def handle( self ): addr = self .request.getpeername() print 'Got connection from' ,addr self .wfile.write( 'Thank you for connection' ) server = Server(('', 1234 ),Handler) server.serve_forever() |
线程Server:
1
2
3
4
5
6
7
8
9
|
from SocketServer import TCPServer, ThreadingMixIn, StreamRequestHandler class Server(ThreadingMixIn, TCPServer): pass class Handler(StreamRequestHandler): def handle( self ): addr = self .request.getpeername() print 'Got connection from' ,addr self .wfile.write( 'Thank you for connecting' ) server = Server(('', 1234 ),Handler) server.serve_forever() |
带有select和pool的异步I/O
select服务:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
import socket, select s = socket.socket() host = socket.gethostname() prot = 1234 s.bind((host,port)) s.listen( 5 ) inputs = [s] while True : rs,ws,es = select.select(inputs,[],[]) for r in rs: if r is s: c, addr = s.accept() print 'Got connection from' ,addr inputs.append(c) else : try : data = r.recv( 1024 ) disconnected = not data except socket.error: disconnected = True if disconnected: print r.getpeername(), 'disconnected' inputs.remove(r) else : print data |
pool服务器:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
import socket, select s = socket.socket() host = socket.gethostname() port = 1234 s.bind((host, port)) fdmap = {s.fileno():s} s.listen( 5 ) p = select.poll() p.register(s) while True : events = p.poll() for fd, event in events: if fd in fdmap: c, addr = s.accept() print 'Got connection from' , addr p.register(c) fdmap[c.fileno()] = c elif event & select.POLLIN: data = fdmap[fd].recv( 1024 ) if not data: print fdmap[fd].getpeername(), 'disconnected' p.unregister(fd) del fdmap[fd] else : print data |
Python网络编程常用代码的更多相关文章
- python 网络编程 TCP/IP socket UDP
TCP/IP简介 虽然大家现在对互联网很熟悉,但是计算机网络的出现比互联网要早很多. 计算机为了联网,就必须规定通信协议,早期的计算机网络,都是由各厂商自己规定一套协议,IBM.Apple和Micro ...
- 图解Python网络编程
返回目录 本篇索引 (1)基本原理 (2)socket模块 (3)select模块 (4)asyncore模块 (5)asynchat模块 (6)socketserver模块 (1)基本原理 本篇指的 ...
- Python学习(22)python网络编程
Python 网络编程 Python 提供了两个级别访问的网络服务.: 低级别的网络服务支持基本的 Socket,它提供了标准的 BSD Sockets API,可以访问底层操作系统Socket接口的 ...
- Day07 - Python 网络编程 Socket
1. Python 网络编程 Python 提供了两个级别访问网络服务: 低级别的网络服务支持基本的 Socket,它提供了标准的 BSD Sockets API,可以访问底层操作系统Socket接口 ...
- 《Python网络编程》学习笔记--使用谷歌地理编码API获取一个JSON文档
Foundations of Python Network Programing,Third Edition <python网络编程>,本书中的代码可在Github上搜索fopnp下载 本 ...
- python 网络编程(Socket)
# from wsgiref.simple_server import make_server## def RunServer(environ,start_response):# start_resp ...
- python 网络编程 IO多路复用之epoll
python网络编程——IO多路复用之epoll 1.内核EPOLL模型讲解 此部分参考http://blog.csdn.net/mango_song/article/details/4264 ...
- python网络编程基础(线程与进程、并行与并发、同步与异步、阻塞与非阻塞、CPU密集型与IO密集型)
python网络编程基础(线程与进程.并行与并发.同步与异步.阻塞与非阻塞.CPU密集型与IO密集型) 目录 线程与进程 并行与并发 同步与异步 阻塞与非阻塞 CPU密集型与IO密集型 线程与进程 进 ...
- Python 网络编程相关知识学习
Python 网络编程 Python 提供了两个级别访问的网络服务.: 低级别的网络服务支持基本的 Socket,它提供了标准的 BSD Sockets API,可以访问底层操作系统Socket接口的 ...
随机推荐
- k8s学习之资料参考网址(持续更新)
此文章持续更新关于学习k8s生态的参考网址: 二进制方式搭建 (此部署方式是一步一步的部署,过程清晰) https://github.com/opsnull/follow-me ...
- Scrapy五大核心组件工作流程
一.Scrapy五大核心组件工作流程 1.核心组件 # 引擎(Scrapy) 对整个系统的数据流进行处理, 触发事务(框架核心). # 调度器(Scheduler) 用来接受引擎发过来的请求. 由过滤 ...
- Java工程师学习指南第1部分:夯实Java基础系列
点击关注上方"Java技术江湖",设为"置顶或星标",第一时间送达技术干货. 本文整理了微信公众号[Java技术江湖]发表和转载过的Java优质文章,想看到更多 ...
- Github搭建个人博客的总结
1. 参考 这个 博客 : https://blog.csdn.net/xudailong_blog/article/details/78762262 2. 把上面按照的就安装,并把git 仓库克隆 ...
- kubernetes资源调度
kubernetes默认情况下创建pod调度是由kubernetes scheduler来管理的,但显然有时候还是需要人为介入.根据目前的kubernetes版本来说,有两种自定义资源调度的方式:No ...
- 【VS开发】Return与Exit的区别
1. exit用于结束正在运行的整个程序,它将参数返回给OS,把控制权交给操作系统:而return 是退出当前函数,返回函数值,把控制权交给调用函数. 2. exit是系统调用级别,它表示一个进程的结 ...
- UWP笔记-自定义Grid背景图片
之前写简单的UWP版本地音乐播放器,有自定义背景壁纸的功能,现在贴在这里回顾下. Page.xaml 页面,添加Grid <Grid x:Name="mainGrid"/&g ...
- [转帖]System Dynamic Management Views
System Dynamic Management Views https://docs.microsoft.com/en-us/sql/relational-databases/system-dyn ...
- pycharm配置git版本管理
1.下载并安装git 首先你电脑必须安装git版本控制器(软件),在官网下载即可 2.安装git,正常安装即可 编缉器的选择,根据电脑实际情况选择合适的编缉器 安装参考:https://www.cnb ...
- B - How many integers can you find
Now you get a number N, and a M-integers set, you should find out how many integers which are smal ...