回顾:
抽象方法
@staticmethod 不能访问类的任何属性
@classmethod 类方法 只能访问公有属性
@property 属性方法 , 把一个方法变成一个静态属性
def sayhi()
pass @sayhi.setter
def sayhi(k): @sayhi.delter
def sayhi(): __call__() : 实例 + ()会触发call method __dict__ 打印实例中所有属性 __getitem__ 以字典的形式操作实例 __new__ 先于 __init__执行, 可以在new中自定义类的实例化过程 __str__ 返回实例的字符串形式 __metaclass__ 元类, type() 可以动态创建一个类 try ... except
IOError
ValueError
IndexError
IndentationError
TypeError
try except (IndexError,IndentationError) as e:
print(e) else: raise assert __import__('day9.testmod') hasattr
getattr
setattr
delattr
**********************************
socket s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.bind(address)
s.listen(5)
conn,clientaddr = s.accept
conn.send 推荐书籍:
林达美国
百年孤独
追风筝的人
三杯茶
白鹿原
平凡的世界
三体
浪潮之巅
数学之美
推荐电影:
华尔街之狼
上帝之城
焦土之城
绝美之城 阿甘正传
辛德勒的名单
肖申克的救赎
勇敢的心
角斗士
飘 乱世佳人 after all , tomorrow is another day
血钻
卢旺达饭店
战争之王
教父
楚门的世界
革命之路
帝国的覆灭
当幸福来敲门
千与千寻
哈尔的移动城堡
龙猫
百元之恋 ***********************************************************8
sock_server.py
 import socket
import json
s = socket.socket()
s.bind(('localhost',9000))
s.listen(5)
print('start listen.......')
while True:
conn,client_addr = s.accept()
print('got a new conn:',client_addr) while True:
data = conn.recv(1024)
print('recv data',data)
data = json.loads(data.decode()) if data.get('action') is not None:
if data['action'] == 'put':
#client sends file to server
file_obj = open(data['filename'],'wb')
received_size = 0 while received_size < data['size']:
recv_data = conn.recv(1024)
file_obj.write(recv_data)
received_size += len(recv_data)
print(data['size'],received_size)
else:
print('successfully receviced file [%s]---'%data['filename'])
file_obj.close()
elif data['action'] == 'get':
# client downlands file from server
pass

sock_client.py

 import socket
import os
import json
client = socket.socket()
client.connect(('localhost',9000)) while True:
choice = input('>>').strip()
if len(choice) == 0:continue
cmd_list = choice.split()
if cmd_list[0] == 'put':
if len(cmd_list) == 1:
print('no filename follows after put cmd.')
continue
filename = cmd_list[1]
if os.path.isfile(filename):
file_obj = open(filename,'rb')
base_filename = filename.split('/')[-1]
print(file_obj.name,os.path.getsize(filename))
data_header = {
'action':'put',
'filename':base_filename,
'size':os.path.getsize(filename)
}
client.send( json.dumps(data_header).encode())
for line in file_obj:
client.send(line)
print('----send file down-------') else:
print('file is not vaild.')
continue
elif cmd_list[0] == 'get':
pass
socket_server.py
 import socketserver

 class MyTCPHandler(socketserver.BaseRequestHandler):
def handle(self):
while True:
self.data = self.request.recv(1024).strip()
print(self.client_address[0])
print(self.data)
self.request.send(self.data.upper()) if __name__ == '__main__':
host,port = 'localhost',9000 server = socketserver.TCPServer((host,port),MyTCPHandler) server.serve_forever()
												

Python之路,day9-Python基础的更多相关文章

  1. Python之路,Day4 - Python基础4 (new版)

    Python之路,Day4 - Python基础4 (new版)   本节内容 迭代器&生成器 装饰器 Json & pickle 数据序列化 软件目录结构规范 作业:ATM项目开发 ...

  2. Python之路,Day1 - Python基础1

    本节内容 Python介绍 发展史 Python 2 or 3? 安装 Hello World程序 变量 用户输入 模块初识 .pyc是个什么鬼? 数据类型初识 数据运算 表达式if ...else语 ...

  3. Python之路,Day9 - 异步IO\数据库\队列\缓存

    https://www.cnblogs.com/alex3714/articles/5248247.html http://www.cnblogs.com/wupeiqi/articles/51327 ...

  4. Python之路,Day1 - Python基础1(转载Alex)

    本节内容 Python介绍 发展史 Python 2 or 3? 安装 Hello World程序 变量 用户输入 模块初识 .pyc是个什么鬼? 数据类型初识 数据运算 表达式if ...else语 ...

  5. Python之路,Day1 - Python基础1 --转自金角大王

    本节内容 Python介绍 发展史 Python 2 or 3? 安装 Hello World程序 变量 用户输入 模块初识 .pyc是个什么鬼? 数据类型初识 数据运算 表达式if ...else语 ...

  6. Python之路,Day1 - Python基础1 介绍、基本语法、流程控制

    本节内容 1.python介绍 2.发展史 3.python 2.x or python 3.x ? 4.python 安装 5.第一个程序 Hello World 程序 6.变量 7.用户输入 8. ...

  7. Python之路,Day9, 进程、线程、协程篇

    本节内容 操作系统发展史介绍 进程.与线程区别 python GIL全局解释器锁 线程 语法 join 线程锁之Lock\Rlock\信号量 将线程变为守护进程 Event事件 queue队列 生产者 ...

  8. Python之路:Python简介

    Python前世今生 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间他为了在阿姆斯特丹打发时间,决心开发一个新的脚本解释程序,作为ABC语言的一种继承 ...

  9. Python之路:Python操作 RabbitMQ、Redis、Memcache、SQLAlchemy

    Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度 ...

  10. Python之路-初识python及环境搭建与测试(Python安装、Anaconda安装、PyCharm安装)

    一.认识Python 起源 Python的作者是著名的“龟叔”Guido van Rossum,他希望有一种语言,这种语言能够像C语言那样,能够全面调用计算机的功能接口,又可以像shell那样,可以轻 ...

随机推荐

  1. 野心勃勃的React组件生命周期

    当你还在写着Angular指令,过滤器,注入,服务,提供者,视图模版的时候,是不是觉得很烦,好在这个时候,React已经神一样的出现在历史舞台. React组件    React实现了UI=Fn(St ...

  2. jquery 如何去除select 控件重复的option

    这个去重不是很好用,如果id值不同,text是一样的,也会被去掉 <input type="button" class="btn" id="bt ...

  3. entity framework 新手入门篇(3)-entity framework实现orderby,count,groupby,like,in,分页等

    前面我们已经学习了entityframework的基本的增删改查,今天,我们将在EF中实现一些更加贴近于实际功能的SQL方法. 承接上面的部分,我们有一个叫做House的数据库,其中包含house表和 ...

  4. 构造一个简单的Linux系统MenuOS

    陈智威20135125 原创作品转载请注明出处 <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 实验指导 ...

  5. Eclipse默认空间与工作空间的更改(转)

    一.更改eclipse默认空间 进行 eclipse 目录下的 configuration 目录, 打开config.ini文件 将 osgi.instance.area.default= 项修改成你 ...

  6. WPF(WP7、WP8)实现圆形图片

    在WP平台上制作图片圆角其实特别简单, 用Image控件的Clip属性即可(RadiusX-Y设置为图片尺寸的一半) <Image Source="{Binding photo}&qu ...

  7. Winscp sftp远程linux服务器需要预设密码,怎么解决

    需要在root账户下修改/etc/ssh/sshd_config 文件中PermitEmptyPasswords no改成yes

  8. Objective-C 中,atomic原子性一定是安全的吗?

    我们在学习OC的时候认为,atomic使用了原子性,保证了线程安全,事实真的是这样吗? nonatomic的内存管理语义是非原子性的,非原子性的操作本来就是线程不安全的,而atomic的操作是原子性的 ...

  9. SSL/TLS协议运行机制

      转载自http://www.ruanyifeng.com/blog/2014/02/ssl_tls.html 互联网的通信安全,建立在SSL/TLS协议之上. 本文简要介绍SSL/TLS协议的运行 ...

  10. FZU 1759 欧拉函数 降幂公式

    Description   Given A,B,C, You should quickly calculate the result of A^B mod C. (1<=A,C<=1000 ...