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接口的 ...
随机推荐
- PJzhang:钓鱼域名生成工具urlcrazy
猫宁!!! www.baidu.com和www.baibu.com是不是很相似,urlcrazy可以自动生成一大批. 这款工具的作者是Andrew Horton 工具下载地址: http://www. ...
- windows下安装配置winpcap
winpcap官网:http://www.winpcap.org/ 1.首先下载安装winpcap.exe,http://www.winpcap.org/install/default.htm 目的是 ...
- K8s架构详解
每个微服务通过 Docker 进行发布,随着业务的发展,系统中遍布着各种各样的容器.于是,容器的资源调度,部署运行,扩容缩容就是我们要面临的问题. 基于 Kubernetes 作为容器集群的管理平台被 ...
- 使用mybatis出现异常:invalid comparison: java.time.LocalDateTime and java.lang.String
整了半天终于找到问题所在:在mapper文件中,对该参数进行了和字符串的对比,如下: <if test="startTime != null and startTime != '' a ...
- 【AtCoder】AGC033(A-F)
AGC033 A - Darker and Darker 直接BFS #include <bits/stdc++.h> #define fi first #define se second ...
- npm—入门指导
npm npm是什么? NPM(node package manager),通常称为node包管理器.顾名思义,它的主要功能就是管理node包,包括:安装.卸载.更新.查看.搜索.发布等. npm的背 ...
- pycharm 关联 maya
设置pycharm代码自动补全 + pycharm关联maya 一.pycharm 设置 python环境,设置代码自动补全 1.devkit 选择对应版本进行下载https://www.autode ...
- 关于泛型擦除的知识(来源于csdn地址:https://blog.csdn.net/briblue/article/details/76736356)
泛型,一个孤独的守门者. 大家可能会有疑问,我为什么叫做泛型是一个守门者.这其实是我个人的看法而已,我的意思是说泛型没有其看起来那么深不可测,它并不神秘与神奇.泛型是 Java 中一个很小巧的概念,但 ...
- Python取值的灵活性用法
samp_string = "Whatever you are, be a good one." for i in samp_string: print(i) ,len(samp_ ...
- 用Activator.CreateInstance代替new实现类的实例化
一直想得到这样一个函数,输入一个类的名称为参数,返回一个相应的类的实例. 这在工厂模式中是非常有用的 这样,可以使程序有更高的扩展性,例如,,下面的例子 如果现在有一个类,专门用来计算交通工具的速度, ...