FTP做作业用到的知识点:
FTP做作业用到的知识点:
一: os.path 模块下常用的用法
os.path.abspath(file) #返回的是.py文件的绝对路径(完整路径)
os.path.dirname(file) #返回的是.py文件的目录
os.path.dirname(os.path.abspath(file)
os.path.isfile(file) #测试指定参数是否是一个文件
os.path.existsfile() #测试指定文件是否存在
os.path.join(file) #将目录名和文件的基名拼接成一个完整的路径
os.stat(file).st_siaz #获取一个文件的大小
os.path.isdir(file) #用于判断对象是否为一个目录
参考博客:https://www.cnblogs.com/renpingsheng/p/7065565.html
二: sys 模块下常用的用法
- 1 .sys.argv
在一个luffy_server.py文件里面导入sys模块print(sys.argv)或者print(sys.argv[0]) 是指这个脚本本身
#luffy_server.py文件
import sys
print(sys.argv)
返回:这个脚本本身,列表形式
['E:/模块三__FTP作业_2018__11__08/luffyFTP/server/bin/luffy_server.py']
- 2.sys.path.append()
sys.path —— 动态地改变Python搜索路径
在python中导入的package或module不在环境变量PATH中,那么可以使用sys.path.apend 将要导入的package或module加入到PATH环境变量中
import os, sys
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(file)))print(BASE_DIR) #E:\模块四__作业\FTP\server
sys.path.append(BASE_DIR)
三,字典 update()方法
update()
Python update() 函数把字典参数 dict2 的 key/value(键/值) 对更新到字典 dict 里。
参考博客:http://www.runoob.com/python3/python3-att-dictionary-update.html
四:zfill()方法
参考博客:http://www.runoob.com/python3/python3-string-zfill.html
五:反射:hasattr,getattr,setattr,delattr
类的反射特点:类,只能找类里的成员对象
博客链接:https://www.cnblogs.com/sunny7/p/9715856.html
五:yield的应用:
# yield的应用,在FTP作业显示进度条的应用
def run():
count = 0
while True:
n = yield count
print('--->', n, count)
count +=1
g = run()
g.__next__()
g.send('alex')
g.send('jack')
g.send('raom')
g.send('sd')
返回结果:
---> alex 0
---> jack 1
---> raom 2
---> sd 3
下面是应用的例子:显示进度条
def progress_bar(self,total_size,current_percent =0,last_percent = 0): #
while True:
received_size = yield current_percent
current_percent = int(received_size / total_size * 100)
if current_percent > last_percent: # 当前的比上一次的大了
print('#' * int(current_percent / 2) + '{percent} %'.format(percent=current_percent), end='\r',
flush=True) # 打印进度的时候覆盖上一次的,进度条,后面要加换行\n
last_percent = current_percent # 把本次循环的percent赋值给last
六: 模块 configparser
博客链接:https://www.cnblogs.com/sunny7/p/9906491.html
七:shelve模块
# shelve模块
# 向内存里存字典一样把数据存在硬盘里
import shelve
s = shelve.open('') #打开一个文件
print(s) #<shelve.DbfilenameShelf object at 0x0000000001DAC0B8>
list(s.keys())
s['name'] = 'alex'
s['age'] = 18
print(list(s.keys())) #['name', 'age'
print(s['name']) #alex
print(s['age']) #18
s.close()
# 应用:
import shelve
d = shelve.open('shelve_test')
class Test():
def __init__(self,n):
self.n = n
t = Test(123)
t2 = Test(123987456)
name = ['alex','rain','test']
d['test'] = name
d['t1'] = t
d['t2'] = t2
d.close()
FTP做作业用到的知识点:的更多相关文章
- 课下选做作业实现mypwd
2019-2020-1 20175227 <信息安全系统设计基础> 课下选做作业实现mypwd 要求 学习pwd命令 研究pwd实现需要的系统调用(man -k; grep),写出伪代码 ...
- 课下选做作业MyOD
2019-2020-1 20175227 <信息安全系统设计基础> 课下选做作业MyOD 要求 复习c文件处理内容 编写myod.c 用myod XXX实现Linux下od -tx -tc ...
- 课下选做作业MySort
20175227张雪莹 2018-2019-2 <Java程序设计> 课下选做作业MySort 要求 注意:研究sort的其他功能,要能改的动代码,需要答辩 模拟实现Linux下Sort ...
- [LeetCode]1450. 在既定时间做作业的学生人数
给你两个整数数组 startTime(开始时间)和 endTime(结束时间),并指定一个整数 queryTime 作为查询时间. 已知,第 i 名学生在 startTime[i] 时开始写作业并于 ...
- HDU1789 Doing Homework again 做作业【贪心】
题目链接:https://vjudge.net/problem/HDU-1789 题目大意: 给出N个作业的截至日期,和N个作业不交所扣掉的分数,要求输出扣除分数做少的方案. 解析: 与上一道销售商品 ...
- JS基础语法---阶段复习+作业练习+接下来知识点heads up
调试:调试代码---高级程序员都是从调试开始的 调试: 写代码---打开浏览器--F12(开发人员工具)--->Sources---双击文件,在某一行代码前面点击一下(出现的东西就是断点) 一元 ...
- python day 16: FTP脚本作业用例图,类图,活动图与代码重写
目录 python day 16 1. FTP脚本的用例图 python day 16 2019/10/22 - 2019/10/26 学习资料来自老男孩教育 1. FTP脚本的用例图 老师的讲解视频 ...
- python第二十二天-----在做作业当中............
作业 1, ATM:模拟实现一个ATM + 购物商城程序 额度 自定义实现购物商城,买东西加入 购物车,调用信用卡接口结账可以提现,手续费5%支持多账户登录支持账户间转账记录每月日常消费流水提供还款接 ...
- 第三模块:面向对象&网络编程基础 第4章 FTP项目作业讲解
01-FTP项目需求 02-FTP项目框架搭建 03-FTP项目用户认证 04--FTP项目制定标准定长消息头 05-FTP项目下载功能开发 06-FTP项目下载功能开发2 07-FTP项目ls文件列 ...
随机推荐
- Maven 下添加oracle11g的包 报Missing artifact com.oracle:ojdbc6:jar:11.2.0.1.0
Missing artifact com.oracle:ojdbc6:jar:11.2.0.1.0 原因:Oracle 的ojdbc.jar是收费的,所以maven的中央仓库中没有这个资源,只能通过配 ...
- Oracle监听已经启动了 sqlplus / as sysdba 仍然报 ERROR:ORA-12560
我的Oracle是11g的 system 的密码忘记了, 但是scott的密码我还记得而且能登录 . 想以sqlplus /as sysdba 修改system密码 一直在报 ERROR:ORA-12 ...
- Oracle常见错误:ORA-06550、ORA-00911、ORA-02085
ORA-06550:检查标点符号,如果是在写存储过程时候,切记每行每条语句都应该以“;”结束 ORA-00911: invalid character 包含中文报错 ORA-02085:数据库连接 X ...
- mysql 多行(GROUP_CONCAT)和多列(CONCAT)的合并函数
1,多行合并:把查询的一行或者多行进行合并. SELECT GROUP_CONCAT(md.data1) FROM DATA md,contacts cc WHERE md.conskey=cc.id ...
- (8/24) 图片跳坑大战--css中的图片处理
前言:此节的开展是在上一节的基础上进行的,(每一节都是从无到有编写关于此节的知识),最后会附上相关完整代码.上一节 CSS中的图片处理 1.新建images文件夹 在src目录下新建一个images文 ...
- 常见java日志系统的搭配详解:关于slf4j log4j log4j2 logback jul jcl commons-logging jdk-logging
先看一张图: 是不是有点晕, 晕就对了.这个仅仅是 slf4j 的情况,实际上, 我们不仅要接触到 slf4j ,有时候还会接触其他的日志系统.且看下文分解. 1 直接使用各个日志系统 1.1 直接使 ...
- 转载:深入浅出Zookeeper
ZAB协议 ZAB协议是专门为zookeeper实现分布式协调功能而设计.zookeeper主要是根据ZAB协议是实现分布式系统数据一致性. zookeeper根据ZAB协议建立了主备模型完成zook ...
- Linux 系统状态检测命令
介绍快速查看Linux系统运行状态的能力(网络网卡.系统内核.系统负载.内存使用情况.启用终端数量.历史登录记录.命令执行记录.救援诊断)等命令使用方法 1.ifconfig 用于获取网卡配置和网络 ...
- oracle出现sga导致ORA-00821 ORA-00093报错解决办法
本问题在linux环境下,windows环境下类似. 问题描述: 在数据库操作时不小心修改了share_pool的大小,导致重启数据库无法正常启动,报错为: SQL>startup; ORA-: ...
- java中Method.invoke方法参数解析
通过发射的机制,可以通过invoke方法来调用类的函数.invoke函数的第一个参数是调用该方法的实例,如果该方法是静态方法,那么可以用null或者用类来代替,第二个参数是变长的,是调用该方法的参数. ...