标签分类
技术文章
当前位置:主页 > 计算机编程 > python > 详细介绍有关Python+Socket实现基于TCP协议的客户与服务端中文自动回复聊天功能

Python+Socket实现基于TCP协议的客户与服务端中文自动回复聊天功能实现方法

  • 发布时间:
  • 作者:码农之家原创
  • 点击:191

详细介绍有关Python+Socket实现基于TCP协议的客户与服务端中文自动回复聊天功能

这篇文章主要知识点是关于Python,Socket,TCP协议,客户,服务端,自动回复聊天,详细介绍有关Python+Socket实现基于TCP协议的客户与服务端中文自动回复聊天功能,Python+Socket实现基于TCP协议的客户与服务端中文自动回复聊天功能示例 的内容,如果大家想对相关知识点有系统深入的学习,可以参阅以下电子书

全国计算机等级考试二级教程:Python语言程序设计
  • 类型:计算机等级考试大小:7.9 MB格式:PDF出版:高等教育出版社作者:教育部考试中心
立即下载

更多相关的学习资源可以参阅 程序设计电子书Python电子书、等栏目。

这篇文章主要介绍了Python+Socket实现基于TCP协议的客户与服务端中文自动回复聊天功能,结合实例形式分析了Python+Socket实现带自动回复功能的TCP聊天程序相关操作方法与注意事项,需要的朋友可以参考下

 

本文实例讲述了Python+Socket实现基于TCP协议的客户与服务端中文自动回复聊天功能。分享给大家供大家参考,具体如下:

【吐槽】

网上的代码害死人,看着都写的言之凿凿,可运行就是有问题。
有些爱好代码、喜欢收藏代码的朋友,看到别人的代码就粘贴复制过来。可是起码你也试试运行看啊大哥

【正文】

昨日修改运行了UDP协议的C/S聊天程序,可是TCP协议的怎么都不行。各种试,各种坑。

做了下面几个修改后,终于可以了:

1、对发送、接收的信息,分别进行编码和解码
2、客户端的第10行bind改为connect这真是个大坑!!

(本文基于windows 7 + python 3.4)

完整代码如下(人头担保,本人亲测正常!):

服务器端:

 

# tcp_server.py
'''服务器'''
from socket import *
from time import ctime
HOST = '' #主机地址
PORT = 23345 #端口号
BUFSIZ = 2048 #缓存区大小,单位是字节,这里设定了2K的缓冲区
ADDR = (HOST, PORT) #链接地址
tcpSerSock = socket(AF_INET, SOCK_STREAM) #创建一个TCP套接字
tcpSerSock.bind(ADDR) #绑定地址
tcpSerSock.listen(5) #最大连接数为5
while True: #无限循环
  print('尝试连接客户端。。。')
  tcpCliSock, addr = tcpSerSock.accept() #等待接受连接
  print('链接成功,客户端地址为:', addr)
  while True:
    data = tcpCliSock.recv(BUFSIZ) #接收数据,BUFSIZ是缓存区大小
    if not data: break #如果data为空,则跳出循环
    print(data.decode())
    msg = '{} 服务器已接收 [自动回复]'.format(ctime())
    tcpCliSock.send(msg.encode())
  tcpCliSock.close() #关闭连接
tcpSerSock.close() #关闭服务器

客户端:

 

# tcp_client.py
'''客户端'''
from socket import *
from time import ctime
HOST = 'localhost' #主机地址
PORT = 23345 #端口号
BUFSIZ = 2048 #缓存区大小,单位是字节,这里设定了2K的缓冲区
ADDR = (HOST, PORT) #链接地址
tcpCliSock = socket(AF_INET, SOCK_STREAM) #创建一个TCP套接字
#tcpCliSock.bind(ADDR) #绑定地址
tcpCliSock.connect(ADDR) #绑定地址
while True:
  msg = input('请输入:') #输入数据
  if not msg: break #如果 msg 为空,则跳出循环
  tcpCliSock.send(msg.encode())
  data = tcpCliSock.recv(BUFSIZ) #接收数据,BUFSIZ是缓存区大小
  if not data: break #如果data为空,则跳出循环
  print(data.decode())

【运行截图】

实验方法:先运行服务器端,然后运行客户端

详细介绍有关Python+Socket实现基于TCP协议的客户与服务端中文自动回复聊天功能

然后就可以在客户端自由的与服务器端聊天了:

详细介绍有关Python+Socket实现基于TCP协议的客户与服务端中文自动回复聊天功能

以上就是详细介绍有关Python+Socket实现基于TCP协议的客户与服务端中文自动回复聊天功能的详细内容,更多请关注码农之家其它相关文章!

Python+Socket实现基于TCP协议的客户与服务端中文自动回复聊天功能示例

本文实例讲述了Python+Socket实现基于TCP协议的客户与服务端中文自动回复聊天功能。分享给大家供大家参考,具体如下:

【吐槽】

网上的代码害死人,看着都写的言之凿凿,可运行就是有问题。
有些爱好代码、喜欢收藏代码的朋友,看到别人的代码就粘贴复制过来。可是起码你也试试运行看啊大哥

【正文】

昨日修改运行了UDP协议的C/S聊天程序,可是TCP协议的怎么都不行。各种试,各种坑。

做了下面几个修改后,终于可以了:

1、对发送、接收的信息,分别进行编码和解码
2、客户端的第10行bind改为connect这真是个大坑!!

(本文基于windows 7 + python 3.4)

完整代码如下(人头担保,本人亲测正常!):

服务器端:

# tcp_server.py
'''服务器'''
from socket import *
from time import ctime
HOST = '' #主机地址
PORT = 23345 #端口号
BUFSIZ = 2048 #缓存区大小,单位是字节,这里设定了2K的缓冲区
ADDR = (HOST, PORT) #链接地址
tcpSerSock = socket(AF_INET, SOCK_STREAM) #创建一个TCP套接字
tcpSerSock.bind(ADDR) #绑定地址
tcpSerSock.listen(5) #最大连接数为5
while True: #无限循环
  print('尝试连接客户端。。。')
  tcpCliSock, addr = tcpSerSock.accept() #等待接受连接
  print('链接成功,客户端地址为:', addr)
  while True:
    data = tcpCliSock.recv(BUFSIZ) #接收数据,BUFSIZ是缓存区大小
    if not data: break #如果data为空,则跳出循环
    print(data.decode())
    msg = '{} 服务器已接收 [自动回复]'.format(ctime())
    tcpCliSock.send(msg.encode())
  tcpCliSock.close() #关闭连接
tcpSerSock.close() #关闭服务器

客户端:

# tcp_client.py
'''客户端'''
from socket import *
from time import ctime
HOST = 'localhost' #主机地址
PORT = 23345 #端口号
BUFSIZ = 2048 #缓存区大小,单位是字节,这里设定了2K的缓冲区
ADDR = (HOST, PORT) #链接地址
tcpCliSock = socket(AF_INET, SOCK_STREAM) #创建一个TCP套接字
#tcpCliSock.bind(ADDR) #绑定地址
tcpCliSock.connect(ADDR) #绑定地址
while True:
  msg = input('请输入:') #输入数据
  if not msg: break #如果 msg 为空,则跳出循环
  tcpCliSock.send(msg.encode())
  data = tcpCliSock.recv(BUFSIZ) #接收数据,BUFSIZ是缓存区大小
  if not data: break #如果data为空,则跳出循环
  print(data.decode())

【运行截图】

实验方法:先运行服务器端,然后运行客户端

Python+Socket实现基于TCP协议的客户与服务端中文自动回复聊天功能示例

然后就可以在客户端自由的与服务器端聊天了:

Python+Socket实现基于TCP协议的客户与服务端中文自动回复聊天功能示例

更多关于Python相关内容可查看本站专题:《Python Socket编程技巧总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》

希望本文所述对大家Python程序设计有所帮助。

以上就是本次给大家分享的全部知识点内容总结,大家还可以在下方相关文章里找到解决axios.interceptors.respon、 详解vue axios封装请求状态、 儿童python编程入门书籍推、 等python文章进一步学习,感谢大家的阅读和支持。

上一篇:Python中线程的MQ消息队列实现及优缺点详解

下一篇:处理Django中的favicon.ico图标实例方法

展开 +

收起 -

学习笔记
网友NO.239004

Python实现微信自动验证好友、回复、发送链接方法

引言: 一开始二维码加群,但是呢,这个东西隔一段时间会过期,我需要 每隔一段时间去更新二维码,然后当群人数超过100人了,只能邀请进群, 这个时候就需要别人添加我为好友,然后我通过,打开交流群,添加成员, 然后滚列表,一个个翻,找到那个人,然而我通讯录几百个人...后来我学会 了用标签,虽然可以过滤一部分人,但是还是要翻;还有一个问题就是, 加我的人时间的随机性,早上,下午,或者晚上,甚至还有深夜3,4点 加我的,最尴尬的是,刚拉完一个人,又有一个人加我,我又得拉一次... 还有一点就是不想陌生人窥探自己的朋友圈... 作为一个Pyer,肯定要想办法解决上述这些问题,解放自己的双手啊, 让机器人来帮我做这些事,说干就干,立马分析一波实现流程。 流程分析 大概流程如下: Step 1.被添加好友,过滤关键词,看是否包含Py,Python 字(pi)眼,如果包含, 通过请求,并说一句欢迎词的骚话; Step 2.过滤用户发送的关键词,响应相关信息: 1.加群:发送加群链接 2.博客:返回我的掘金主页链接 3.公众号:返回公众号二维码图片 4.打赏:返回一个动图,感谢词,微信付款二维码 5.其他:返回一个黑人问号图片 流程是挺简单的,然而实际实现的时候一堆问题,大部分时间都在试错, 翻issues,谷歌……

网友NO.374411

python登录WeChat 实现自动回复实例详解

最近实现了一些微信的简单玩法我们可以通过网页版的微信微信网页版,扫码登录后去抓包爬取信息,还可以post去发送信息。 》》安装itchat这个库 pip install itchat 先来段简单的试用,实现微信的登录,运行下面代码会生成一个二维码,扫码之后手机端确认登录,就会发送一条信息给‘filehelper',这个filehelper就是微信上的文件传输助手。 import itchat# 登录itchat.login()# 发送消息itchat.send(u'你好鸭!', 'filehelper') 它会给这个文件传输助手自动发送你好鸭! 除了登录和发送消息我们还可以这么来玩,往下走~ 》》实现微信好友男女比例 想统计下自己微信里好友的性别比例,当然也是很简单,先获取好友列表,统计列表里性别计数 import itchat# 先登录itchat.login()# 获取好友列表friends = itchat.get_friends(update=True)[0:]# 初始化计数器,有男有女,当然,有些人是不填的male = female = other = 0# 遍历这个列表,列表里第一位是自己,所以从"自己"之后开始计算# 1表示男性,2女性for i in friends[1:]: sex = i["Sex"] if sex == 1: male += 1 elif sex == 2: female += 1 else: other += 1# 总数算上,好计算比例啊~total = len(friends[1:])# 好了,打印结果print (u"男性好友:%.2f%%" % (float(male) / total * 100))print (u"女性好友:%.2f%%" % (float(female) / total * 100))print (u"其他:%.2f%%" % (float(other) / total……

网友NO.528356

Python+Socket实现基于TCP协议的客户与服务端中文自动回复聊天功能示例

本文实例讲述了Python+Socket实现基于TCP协议的客户与服务端中文自动回复聊天功能。分享给大家供大家参考,具体如下: 【吐槽】 网上的代码害死人,看着都写的言之凿凿,可运行就是有问题。 有些爱好代码、喜欢收藏代码的朋友,看到别人的代码就粘贴复制过来。可是起码你也试试运行看啊大哥 【正文】 昨日修改运行了UDP协议的C/S聊天程序,可是TCP协议的怎么都不行。各种试,各种坑。 做了下面几个修改后,终于可以了: 1、对发送、接收的信息,分别进行编码和解码 2、 客户端的第10行bind改为connect ( 这真是个大坑!! ) (本文基于windows 7 + python 3.4) 完整代码如下(人头担保,本人亲测正常!): 服务器端: # tcp_server.py'''服务器'''from socket import *from time import ctimeHOST = '' #主机地址PORT = 23345 #端口号BUFSIZ = 2048 #缓存区大小,单位是字节,这里设定了2K的缓冲区ADDR = (HOST, PORT) #链接地址tcpSerSock = socket(AF_INET, SOCK_STREAM) #创建一个TCP套接字tcpSerSock.bind(ADDR) #绑定地址tcpSerSock.listen(5) #最大连接数为5while True: #无限循环 print('尝试连接客户端。。。') tcpCliSock, addr = tcpSerSock.accept() #等待接受连接 print('链接成功,客户端地址为:', addr) while True: data = tcpCliSock.recv(BUFSIZ) #接收数据,BUFSIZ是缓存区大小 if not data: break #如果data为空,则……

网友NO.499572

python实现人人自动回复、抢沙发功能

最近人人上看到有好友总是使用软件抢沙发,便决定用Python也写一个玩玩 一、状态回复表单POST 同样使用chrome开发者工具抓包 红色选择选中部分为必须提交的部分 提交表单的内容 postdata = { 'c': content, #1 你要评论的内容 'owner': owner, #2 该状态的所有者ID 'source': source, #3 该状态的ID 't': 3, #4 这条不用修改 'requestToken': xxx, #5 上图选中部分 '_rtk': 'xxx', #6 上图选中部分 } 二、抢沙发思路 每个20s访问一下人人主页,使用BeautifulSoup抓取data-id(对应owner)、data-source(对应source) 模拟表单提交即可完成抢沙发 TARGET_ID 集合存放需要抢沙发的好友ID(data-id) REPLY_ID 集合存放已经回复过的状态ID(data-source) 通过上述两个集合保证不重复评论,且只评论指定好友的状态 #coding=utf8 import re import urllib import urllib2 import time from bs4 import BeautifulSoup __author__ = 'SnOw' COOKIE = '你自己COOKIE' HEADERS = {'cookie': COOKIE, 'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_0) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36' } TARGET_ID = set(['5002986XX']) #存放需要抢沙发的好友ID REPLY_ID = set() def load_status(): URL = 'http://www.renren.com/' req = urllib2.Request(URL, headers=HEADERS) page = '' try: page = urllib2.urlopen(req).read() except: print 'urlopen error' soup = BeautifulSoup(page) for i in soup.find_all('figure'): # prin……

<
1
>

Copyright 2018-2019 xz577.com 码农之家

版权责任说明