前言

才吃完火锅嘿嘿,吃完把今天所学的内容写个博客当做笔记用哈哈!

文件操作

f=open("test.txt",w)直接打开一个文件,如果文件不存在则创建文件
open模式
w:以写方式打开,
a:以追加模式打开 (从 EOF 开始, 必要时创建新文件)
r+:以读写模式打开
w+:以读写模式打开 (参见 w )
a+:以读写模式打开 (参见 a )
rb:以二进制读模式打开
wb:以二进制写模式打开 (参见 w )
ab:以二进制追加模式打开 (参见 a )
rb+:以二进制读写模式打开 (参见 r+ )
wb+:以二进制读写模式打开 (参见 w+ )
ab+:以二进制读写模式打开 (参见 a+ )

fp.read([size]) #size为读取的长度,以byte为单位
fp.readline([size]) #读一行,如果定义了size,有可能返回的只是一行的一部分
fp.readlines([size]) #把文件每一行作为一个list的一个成员,并返回这个list。其实它的内部是通过循环调用readline()来实现的。如果提供size参数,size是表示读取内容的总长,也就是说可能只读到文件的一部分。
fp.write(str) #把str写到文件中,write()并不会在str后加上一个换行符
fp.writelines(seq) #把seq的内容全部写到文件中(多行一次性写入)。这个函数也只是忠实地写入,不会在每行后面加上任何东西。
fp.close() #关闭文件。python会在一个文件不用后自动关闭文件,不过这一功能没有保证,最好还是养成自己关闭的习惯。 如果一个文件在关闭后还对其进行操作会产生ValueError
fp.flush() #把缓冲区的内容写入硬盘
fp.fileno() #返回一个长整型的”文件标签“
fp.isatty() #文件是否是一个终端设备文件(unix系统中的)
fp.tell() #返回文件操作标记的当前位置,以文件的开头为原点
fp.next() #返回下一行,并将文件操作标记位移到下一行。把一个file用于for … in file这样的语句时,就是调用next()函数来实现遍历的。
fp.seek(offset[,whence]) #将文件打操作标记移到offset的位置。这个offset一般是相对于文件的开头来计算的,一般为正数。但如果提供了whence参数就不一定了,whence可以为0表示从头开始计算,1表示以当前位置为原点计算。2表示以文件末尾为原点进行计算。需要注意,如果文件以a或a+的模式打开,每次进行写操作时,文件操作标记会自动返回到文件末尾。
fp.truncate([size]) #把文件裁成规定的大小,默认的是裁到当前文件操作标记的位置。如果size比文件的大小还要大,依据系统的不同可能是不改变文件,也可能是用0把文件补到相应的大小,也可能是以一些随机的内容加上去。

目录操作方法

1.创建目录
os.mkdir("file")
2.复制文件:
shutil.copyfile("oldfile","newfile") #oldfile和newfile都只能是文件
shutil.copy("oldfile","newfile") #oldfile只能是文件夹,newfile可以是文件,也可以是目标目录
3.复制文件夹:
4.shutil.copytree("olddir","newdir") #olddir和newdir都只能是目录,且newdir必须不存在
5.重命名文件(目录)
os.rename("oldname","newname") #文件或目录都是使用这条命令
6.移动文件(目录)
shutil.move("oldpos","newpos")
7.删除文件
os.remove("file")
8.删除目录
os.rmdir("dir") #只能删除空目录
shutil.rmtree("dir") #空目录、有内容的目录都可以删
9.转换目录
os.chdir("path") #换路径

参考学习:https://www.cnblogs.com/mttnor/p/python.html

python实现简单web路径扫描

strip() 方法用于移除字符串头尾指定的字符
sys.argv: 实现从程序外部向程序传递参数。

 1 # coding:utf-8
2 import requests
3 import sys
4 url = sys.argv[1]
5 with open("dir.txt","r") as f:
6 for line in f.readlines():
7 line=line.strip()
8 r=requests.get(url+line)
9 if r.status_code==200:
10 print("url:"+r.url+"exist")

Python实现 IIS PUT漏洞探测

 1 # coding:utf-8
2 import requests
3 url="http://127.0.0.1"
4 r=requests.options(url)
5
6 result=r.headers['Public']
7 if result.find("PUT") and result.find("MOVE"):
8 print(result)
9 print("exist iis put vul")
10 else:
11 print("not exist")

最新文章

  1. Java基础-输入输出-2.编写IoDemo.java的Java应用程序,程序完成的功能是:首先读取text.txt文件内容,再通过键盘输入文件的名称为iodemo.txt,把text.txt的内容存入iodemo.txt
  2. javase基础复习攻略《三》
  3. Libpcap
  4. AtCoder Regular Contest 076
  5. 自古枪兵幸运E
  6. 【python小练】图片爬虫之BeautifulSoup4
  7. python zip文件压缩和解压
  8. Cleartext HTTP traffic to ... not permitted
  9. 强大的easygrid V7 ,可联系作者
  10. PostgreSQL基础知识与基本操作索引页
  11. arcgis创建渔网
  12. php的zend引擎执行过程 一
  13. php分割字符串方法速度比較(substr/sscanf/preg_match)
  14. 谈谈ConcurrentHashMap1.7和1.8的不同实现
  15. 什么是web?什么是web服务器?什么是应用服务器?
  16. saltstack学习篇
  17. win2003从组策略关闭端口(445/135/137/138/139/3389等)教程
  18. React中的全选反选问题
  19. poj 1012 & hdu 1443 Joseph(约瑟夫环变形)
  20. 洛谷P1144——最短路计数

热门文章

  1. 通俗的讲解Python中的__new__()方法
  2. Window Mysql 解压安装
  3. Python 从入门到精通:一个月就够了
  4. 了解Js中的client,offset
  5. 攻防世界-mfw
  6. 自定义View(进度条)
  7. 如何发布代码到maven中心仓库
  8. D. Alyona and Strings 解析(思維、DP)
  9. D. Generating Sets 解析(思維)
  10. java数据结构-06双向循环链表