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做作业用到的知识点:的更多相关文章

  1. 课下选做作业实现mypwd

    2019-2020-1 20175227 <信息安全系统设计基础> 课下选做作业实现mypwd 要求 学习pwd命令 研究pwd实现需要的系统调用(man -k; grep),写出伪代码 ...

  2. 课下选做作业MyOD

    2019-2020-1 20175227 <信息安全系统设计基础> 课下选做作业MyOD 要求 复习c文件处理内容 编写myod.c 用myod XXX实现Linux下od -tx -tc ...

  3. 课下选做作业MySort

    20175227张雪莹 2018-2019-2 <Java程序设计> 课下选做作业MySort 要求 注意:研究sort的其他功能,要能改的动代码,需要答辩 模拟实现Linux下Sort ...

  4. [LeetCode]1450. 在既定时间做作业的学生人数

    给你两个整数数组 startTime(开始时间)和 endTime(结束时间),并指定一个整数 queryTime 作为查询时间. 已知,第 i 名学生在 startTime[i] 时开始写作业并于 ...

  5. HDU1789 Doing Homework again 做作业【贪心】

    题目链接:https://vjudge.net/problem/HDU-1789 题目大意: 给出N个作业的截至日期,和N个作业不交所扣掉的分数,要求输出扣除分数做少的方案. 解析: 与上一道销售商品 ...

  6. JS基础语法---阶段复习+作业练习+接下来知识点heads up

    调试:调试代码---高级程序员都是从调试开始的 调试: 写代码---打开浏览器--F12(开发人员工具)--->Sources---双击文件,在某一行代码前面点击一下(出现的东西就是断点) 一元 ...

  7. python day 16: FTP脚本作业用例图,类图,活动图与代码重写

    目录 python day 16 1. FTP脚本的用例图 python day 16 2019/10/22 - 2019/10/26 学习资料来自老男孩教育 1. FTP脚本的用例图 老师的讲解视频 ...

  8. python第二十二天-----在做作业当中............

    作业 1, ATM:模拟实现一个ATM + 购物商城程序 额度 自定义实现购物商城,买东西加入 购物车,调用信用卡接口结账可以提现,手续费5%支持多账户登录支持账户间转账记录每月日常消费流水提供还款接 ...

  9. 第三模块:面向对象&网络编程基础 第4章 FTP项目作业讲解

    01-FTP项目需求 02-FTP项目框架搭建 03-FTP项目用户认证 04--FTP项目制定标准定长消息头 05-FTP项目下载功能开发 06-FTP项目下载功能开发2 07-FTP项目ls文件列 ...

随机推荐

  1. 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的中央仓库中没有这个资源,只能通过配 ...

  2. Oracle监听已经启动了 sqlplus / as sysdba 仍然报 ERROR:ORA-12560

    我的Oracle是11g的 system 的密码忘记了, 但是scott的密码我还记得而且能登录 . 想以sqlplus /as sysdba 修改system密码 一直在报 ERROR:ORA-12 ...

  3. Oracle常见错误:ORA-06550、ORA-00911、ORA-02085

    ORA-06550:检查标点符号,如果是在写存储过程时候,切记每行每条语句都应该以“;”结束 ORA-00911: invalid character 包含中文报错 ORA-02085:数据库连接 X ...

  4. mysql 多行(GROUP_CONCAT)和多列(CONCAT)的合并函数

    1,多行合并:把查询的一行或者多行进行合并. SELECT GROUP_CONCAT(md.data1) FROM DATA md,contacts cc WHERE md.conskey=cc.id ...

  5. (8/24) 图片跳坑大战--css中的图片处理

    前言:此节的开展是在上一节的基础上进行的,(每一节都是从无到有编写关于此节的知识),最后会附上相关完整代码.上一节 CSS中的图片处理 1.新建images文件夹 在src目录下新建一个images文 ...

  6. 常见java日志系统的搭配详解:关于slf4j log4j log4j2 logback jul jcl commons-logging jdk-logging

    先看一张图: 是不是有点晕, 晕就对了.这个仅仅是 slf4j 的情况,实际上, 我们不仅要接触到 slf4j ,有时候还会接触其他的日志系统.且看下文分解. 1 直接使用各个日志系统 1.1 直接使 ...

  7. 转载:深入浅出Zookeeper

    ZAB协议 ZAB协议是专门为zookeeper实现分布式协调功能而设计.zookeeper主要是根据ZAB协议是实现分布式系统数据一致性. zookeeper根据ZAB协议建立了主备模型完成zook ...

  8. Linux 系统状态检测命令

    介绍快速查看Linux系统运行状态的能力(网络网卡.系统内核.系统负载.内存使用情况.启用终端数量.历史登录记录.命令执行记录.救援诊断)等命令使用方法 1.ifconfig  用于获取网卡配置和网络 ...

  9. oracle出现sga导致ORA-00821 ORA-00093报错解决办法

    本问题在linux环境下,windows环境下类似. 问题描述: 在数据库操作时不小心修改了share_pool的大小,导致重启数据库无法正常启动,报错为: SQL>startup; ORA-: ...

  10. java中Method.invoke方法参数解析

    通过发射的机制,可以通过invoke方法来调用类的函数.invoke函数的第一个参数是调用该方法的实例,如果该方法是静态方法,那么可以用null或者用类来代替,第二个参数是变长的,是调用该方法的参数. ...