回顾:
抽象方法
@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. centos 6 SSH配置Google Authentication 验证

    创建工作目录: mkdir google-authentication 1. 安装二维码生成依赖 #wget http://fukuchi.org/works/qrencode/qrencode-3. ...

  2. php项目中使用memcache

    memcache为分布式内存缓存系统,通过在内存中存取数据和对象减少对数据库的访问从而减轻数据库的负载,memcache分为客户端和服务端,服务端为C实现,有现成的服务端应用程序,无需开发,只需要配置 ...

  3. 使用crosswalk优化ionic2应用包

    ionic plugin add cordova-plugin-crosswalk-webview --save

  4. ionic cordova 热更新(引用自www.zyyapp.com/post/116.html)

    上篇文章cordova 把html打包成安卓应用 http://www.zyyapp.com/post/115.html cordova 热更新是一个大坑,我看了一天一夜才明白.网上的教程都没说到重点 ...

  5. iOS学习之设计模式

    iOS开发学习中,经常弄不清楚ios的开发模式,今天我们就来进行简单的总结和探讨~ (一)代理模式 应用场景:当一个类的某些功能需要由别的类来实现,但是又不确定具体会是哪个类实现. 优势:解耦合 敏捷 ...

  6. Python学习路程CMDB

    本节内容 浅谈ITIL CMDB介绍 Django自定义用户认证 Restful 规范 资产管理功能开发 浅谈ITIL TIL即IT基础架构库(Information Technology Infra ...

  7. ORB

    http://wenku.baidu.com/link?url=R4Ev8aJNxwmjV0egSUqVBjmnt1KT_llzp8Oy2NbHnwa7Me9UAIHkiMG2Vwucu3RSDKwy ...

  8. 深入理解JavaScript系列:试着谈谈闭包

    闭包可能是JavaScript里最被人神乎其神的一个概念,世间万物皆凡夫俗子,你觉着他神奇是因为你根本没有了解,所有的事物当你了解透彻后就不会有这种不明觉厉的错觉了.哈哈哈,上来又是一顿哲学普及. 下 ...

  9. "****" is not translated in zh, zh_CN.的解决方法

    最近在开发一个app,要用到静默安装等一些小技术,但是引发了问题如下: 在Android SDK Tool r19之后, Export的时候遇到xxx is not translated in yyy ...

  10. Win10/UWP新特性—SharedStorageAccessManager 共享文件

    首先先给大家推荐一个UWP/Win10开发者群:53078485  里面有很多大婶,还有很多学习资源,欢迎大家来一起讨论Win10开发! 在UWP开发中,微软提供了一个新的特性叫做SharedStor ...