设为首页 收藏本站
查看: 1957|回复: 0

[经验分享] Python里的OS模块常用函数说明

[复制链接]

尚未签到

发表于 2015-4-25 11:28:28 | 显示全部楼层 |阅读模式
  Python的标准库中的os模块包含普遍的操作系统功能。如果你希望你的程序能够与平台无关的话,这个模块是尤为重要的。即它允许一个程序在编写后不需要任何改动,也不会发生任何问题,就可以在Linux和Windows下运行。
  下面列出了一些在os模块中比较有用的部分。它们中的大多数都简单明了。  
  os.sep可以取代操作系统特定的路径分隔符。windows下为 “\\”
  os.name字符串指示你正在使用的平台。比如对于Windows,它是'nt',而对于Linux/Unix用户,它是'posix'。
  os.getcwd()函数得到当前工作目录,即当前Python脚本工作的目录路径。
  os.getenv()获取一个环境变量,如果没有返回none
  os.putenv(key, value)设置一个环境变量值
  os.listdir(path)返回指定目录下的所有文件和目录名。
  os.remove(path)函数用来删除一个文件。
  os.system(command)函数用来运行shell命令。
  os.linesep字符串给出当前平台使用的行终止符。例如,Windows使用'\r\n',Linux使用'\n'而Mac使用'\r'。
  os.path.split(p)函数返回一个路径的目录名和文件名。
  os.path.isfile()和os.path.isdir()函数分别检验给出的路径是一个文件还是目录。
  os.path.existe()函数用来检验给出的路径是否真地存在

  os.curdir:返回当前目录('.')
os.chdir(dirname):改变工作目录到dirname
  os.path.getsize(name):获得文件大小,如果name是目录返回0L
  os.path.abspath(name):获得绝对路径
os.path.normpath(path):规范path字符串形式
  os.path.splitext():分离文件名与扩展名
os.path.join(path,name):连接目录与文件名或目录
os.path.basename(path):返回文件名
os.path.dirname(path):返回文件路径  
  第一个python程序(python 3.1.2)
  
  创建文件(makeTextFile.py)
"这个脚本提醒用户输入一个(尚不存在的)文件名,然后由用户输入该文件的每一行。最后,将所有文本写入文件"
#!/user/bin/env python
'makeTextFile.py -- create text file'
import os
ls = os.linesep
#get filename
filename = input('Enter a file name:')
while True:
if os.path.exists(filename):
print("ERROR: '%s' already exists" % filename)
else:
break
#get file content(text) lines
all = []
print("\nEnter lines ('.' by iteself to quit).\n")
#loop until user terminates input
while True:
entry = input('>')
if entry == '.':
break
else:
all.append(entry)
#write lines to file with proper line-ending
fobj = open(filename, 'w')
fobj.writelines(['%s%s' %(x, ls) for x in all])
fobj.close()
print("Done!")

  

  程序很简单,相对复杂的就下面这句话
fobj.writelines(['%s%s' %(x, ls) for x in all])

这个列表解析,把每行字符加上一个行结束符写入到文件里。  
  读取文件(readTextFile.py)
#!/user/bin/env python
'readTextFile.py -- read and display text file'
#get file name
fname = input('Enter file name:')
print()
#attempt to open file for reading
try:
fobj = open(fname, 'r')
except IOError as e:
print("*** file open error", e)
else:
#display contents to the screen
for eachLine in fobj:
print(eachLine, end='')        
fobj.close()

  这个里面加入了一些异常处理
  里面可能比较奇怪的就是我自己修改的这句话了
        print(eachLine, end='')      

  print里面加入end=’’这个参数可以消除print自身添加的换行符,那样就是可以保持输出显示是和原文件一模一样了,不然每行就会多个换行符。
  
  你还可以采用这样的方法来去掉那个换行符
  print(eachLine.strip())

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-60541-1-1.html 上篇帖子: Python 利用HTMLParser做网络爬虫 下篇帖子: 用Python捕获snmp trap
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表