文件操作

 打开文件:文件句柄 = open('文件路径''模式')

 打开文件的模式
w                     #以写的方式打开   (不可读,不存在则创建,存在则删除内容)
a #以追加的模式打开(可读, 不存在则创建,存在则追加内容)
r #以只读模式打开
"+" 表示可以同时读写某个文件
r+ #以读写的模式打开
w+ #以读写的模式打开
a+ #以读写的模式打开 "b”表示处理二进制文件
rb        #以二进制模式读打开
wb        #以二进制写模式打开
ab        #以二进制追加模式打开 rb+          #以二进制读写模式打开
wb+         #以二进制读写模式打开
ab+          #以二进制读写模式打开 "U" 表示在读取时,可以将\r \n \r\n 自动转换成\n (与r或者r+模式相同)
rU
r+U3
fp = open("test.txt",w)
fp.close    #关闭文件, 养成习惯,打开文件,用完后,记得关闭,否则有可能报ValueError
fp.fileno     #返回一个文件描述符,使用底层的操作请求系统 I/O操作
fp.flush    #刷新文件内容缓冲区
fp.isatty    #文件是否是一个终端设备文件(unix系统中的)
fp.next   #获取下一行的数据,不 存在则报错 。 for i in file: print i.strip() 就是调用这个next()方法
fp.read([size]) #读取指定字节数的数据 以byte 为单位
fp.readline([size]) #读一行,如果定义了size ,有可能返回一行中的部分
fp.readlines([size]) #把文件每一行作为一个list的一个成员,并返回这个list。内部还是调用readline()方法
fp.seek(offset[,whence]) #将文件操作移动到offset的位置,这个offset一般相对文件的开头开计算的,一般为整数,
#0 从头开始计算
#1 从当前位置开始计算
#2 从未见末尾开始计算
fp.tell #告诉文件操作的当前位置 ,从开头开始计算
fp.truncate #把文件裁成规定的大小,默认是裁到当前文件操作标记的位置
fp.write #往文件里面写内容
fp.writelines #将一个字符串列表写入文件
fp.closed #关闭文件
fp.encoding  
fp.errors                
fp.mode              
fp.name              
fp.newlines            
fp.softspace          

  

 

with 应用

 1,为了避免打开文件后,忘记关闭, 可以通过管理上下文: 
with open("log.txt","r") as f:                #只读的方式打开文件,alias 为f
for line in f:
print line #打印每一行
#执行完成后内部会自动关闭并释放文件资源

  

 
 2, 在python2.7后,with又支持同时对多个文件的上下文进行管理
with open("log1.txt") as obj1  , open("log2.txt")  as obj2:    #可以进行复制的操作
for line in obj1:
obj2.write(line)

  

python每行读取文件几种姿势

#1 ,readline
file = open("a.log","r")  
whileTrue:
line = file.readline()
if not line:
break
pass
#2 ,fileinput
import fileinput
file = open("a.log","r")
for line in fileinput.input("a.log"):
pass #3 ,readlines
file = open("a.log","r")
whileTrue:
lines = file.readlines(100000)
if not lines:
break
for line in lines:
pass
#4 ,for循环
file = open("a.log","r") # 相当于with open("a.log","r") as f:
# for line in f:
for line in file: # pass
pass #5 ,xreadlines
file = open("a.log","r") #已经废弃
for line in file.xreadlines():
pass

         

自定义函数

 在学习函数之前,一直都是遵循面向过程编程,类似于shell脚本的功能,靠堆积一些命令来处理一些事情,按照业务的罗技从上到下的实现功能
 
  1. whileTrue:
    if cpu利用率> 90%:
    #发送邮件提醒
    连接邮箱服务器
    发送邮件
    关闭连接 if 硬盘使用空间> 90%:
    #发送邮件提醒
    连接邮箱服务器
    发送邮件
    关闭连接 if 内存占用> 80%:
    #发送邮件提醒
    连接邮箱服务器
    发送邮件
    关闭连接

    看一下上面的代码 ,可以将if 语句内容提取出来公用,如下:

def 发送邮件(内容)
#发送邮件提醒
连接邮箱服务器
发送邮件
关闭连接 while True: if cpu利用率> 90%:
发送邮件('CPU报警') if 硬盘使用空间> 90%:
发送邮件('硬盘报警') if 内存占用> 80%:
发送邮件("内存报警")
 对于上述俩种实现的方式 ,第二次显示比第一次的重用性和可读性要好,其实这也是函数式编程和面向过程编程的区别
           函数式:将某功能代码封装到函数中, 日后便无需重复编写,仅需要调用函数即可
           面向对象:对函数进行分类和封装,让开发"更快,更强。。。" 
 函数式编程最重要的是增强代码的重用性和可读性          
 

函数的定义和使用

  1. def  foo(args):
    print "hello,world!"
    return args
    ret = foo(name)
    print ret

      

 注意: 上面是调用一个函数 ,写错了
             foo(name) 改为 foo("name")

函数的参数

 为什么要使用参数  ?
  1. def 发送邮件(邮件内容)                  #邮件内容为参数
    #发送邮件提醒
    连接邮箱服务器
    发送邮件
    关闭连接
    whileTrue:
    if cpu利用率>90%:
    发送邮件("CPU报警了。")
    if硬盘使用空间>90%:
    发送邮件("硬盘报警了。")
    if内存占用>80%:
    发送邮件("内存报警了。")

函数中参数的种类

 1 , 普通参数 
 
  1. def func(args):
    print args
    func("budonghsu")

      

 
 
 2 ,默认参数
  1. def func(name,age =18):
    print "%s : %s"%(name,age)
    func("budongshu",19)
    func("budongshu") 运行结果:
    budongshu :19
    budongshu :18

      

 注意:默认参数要放在参数列表的最后面
 
 
 3 , 动态参数 
  1. def func(*arg):              #可以接收列表,元组 ,字符串
    print arg
    执行方式一
    name =[1,2,3,4]
    func(name)
    name =("a","b")
    func(name)
    执行方式二
    func("bds",123) 执行结果: #返回的是一个元组
    ([1, 2, 3, 4],) (('a', 'b'),) ('bds', 123)

      

 
  1. def func(**kwargs):                 #可以接收字典
    print kwargs
    func(name="bds",age=19)    #此方法还可以用来生成字典
    dict1 ={'name':"linux",'age':20}
    func(**dict1)
    运行结果:
    {'age':19,'name':'bds'}
    {'age':20,'name':'linux'}

      

  1. def foo(*arg,**kwargs):
    print 'arg = ', arg
    print 'kwargs =', kwargs
    print '-------------------------'
    foo(1,2,3,4)
    foo(a=1,b=2,c=3)
    foo(1,2,3,4,a=1,b=2,c=3)
    foo('a',1,None,a=1,b='2',c=3)

      

  1.  运行结果:
  2. arg =  (1,2,3,4)
    kwargs ={}
    -------------------------
    arg = ()
    kwargs ={'a':1,'c':3,'b':2}
    -------------------------
    arg = (1,2,3,4)
    kwargs ={'a':1,'c':3,'b':2}
    -------------------------
    arg = ('a',1,None)
    kwargs ={'a':1,'c':3,'b':'2'}
    -------------------------

      

python发邮件

#!/usr/bin/env python
#conding:utf-8 *_* 
import smtplib
from email.mime.text import MIMEText
from email.utils import formataddr
 
 
msg = MIMEText('my name is budongshu', 'plain', 'utf-8')
msg['From'] = formataddr(["budongshu",'bdstravel@126.com'])
msg['To'] = formataddr(["qq",'2329435445@qq.com'])
msg['Subject'] = "hello hero subnet"
 
server = smtplib.SMTP("smtp.126.com", 25)
server.login("bdstravel@126.com", "你的密码")
server.sendmail('bdstravel@126.com', ['2329435445@qq.com',], msg.as_string())
server.quit()
 
 详解如图:
 
 
 测试:
 
 
 
 
 
 
 
 
 
 

python 函数初识和文件操作的更多相关文章

  1. python函数基础 与文件操作

    函数的定义 函数是通过赋值传递的,参数通过赋值传递给函数.def语句将创建一个函数对象并将其赋值给一个变量名,def语句的一般格式如下: def function_name(arg1,arg2[,.. ...

  2. Python函数定义、文件操作(读写、修改)

    date:2018421 day3 一.函数定义 def  函数名(首字母大写) 增加程序可读性 #直接写函数名即可调用函数 #参数 ①.形参 ②.实参 ③.缺省参数 如果有默认值,调用的时候没有传递 ...

  3. python学习笔记-(七)python基础--集合、文件操作&函数

    本节内容 1.集合操作 2.文件操作 3.字符编码与转码 4.函数操作 1.集合操作 集合是一个无序的.不重复的数据组合: 1.1 常用操作 它的作用是: 1)自动去重:列表变成集合,自动去重: &g ...

  4. Python自动化 【第三篇】:Python基础-集合、文件操作、字符编码与转码、函数

    1.        集合 1.1      特性 集合是一个无序的,不重复的数据组合,主要作用如下: 去重,把一个列表变成集合实现自动去重. set可以看成数学意义上的无序和无重复元素的集合,因此,两 ...

  5. Python之旅Day3 文件操作 函数(递归|匿名|嵌套|高阶)函数式编程 内置方法

    知识回顾 常见五大数据类型分类小结:数字.字符串.列表.元组.字典 按存值个数区分:容器类型(列表.字典.元组) 标量原子(数字.字符串) 按是否可变区分:可变(列表.字典) 不可变(数字.字符串.元 ...

  6. python基础3之文件操作、字符编码解码、函数介绍

    内容概要: 一.文件操作 二.字符编码解码 三.函数介绍 一.文件操作 文件操作流程: 打开文件,得到文件句柄并赋值给一个变量 通过句柄对文件进行操作 关闭文件 基本操作: #/usr/bin/env ...

  7. Python基础-week03 集合 , 文件操作 和 函数详解

    一.集合及其运算 1.集合的概念 集合是一个无序的,不重复的数据组合,它的主要作用如下 *去重,把一个列表变成集合,就自动去重了 *关系测试,测试两组数据之前的交集.并集.差集.子集.父级.对称差集, ...

  8. Python基本语法_文件操作_读写函数详解

    目录 目录 软件环境 file文件对象 open文件操作 读文件 read读取所有文件内容 readline获取一行内容 readlines读取所有文件内容 readreadlinereadlines ...

  9. Python基础7:文件操作

    [ 文件操作] 1 对文件操作流程 打开文件,得到文件句柄并赋值给一个变量 通过句柄对文件进行操作 关闭文件 现有文件如下: 昨夜寒蛩不住鸣. 惊回千里梦,已三更. 起来独自绕阶行. 人悄悄,帘外月胧 ...

随机推荐

  1. 【网络流24题】 No.3 最小路径覆盖问题 (网络流|匈牙利算法 ->最大二分匹配)

    [题意] 给定有向图 G=(V,E).设 P 是 G 的一个简单路(顶点不相交) 的集合.如果 V 中每个顶点恰好在 P 的一条路上,则称 P 是 G 的一个路径覆盖. P 中路径可以从 V 的任何一 ...

  2. OSS研究

    在以前没有毕业之前,做过了一个了播放器,其实就是mplayer的二次开发. 如果在这个播放器之上,加个oss作声音输入,那不就可以做个卡拉OK啦? 1.OSS的定义 OSS(Open Sound Sy ...

  3. 【HDOJ】5288 OO’s Sequence

    二分寻找对于指定pos的最左因数点和最右因数点. /* 5288 */ #include <iostream> #include <string> #include <m ...

  4. 面向中国 Azure 开发者发布开源解决方案指南

     发布于 2014-05-23 作者 刘 天栋 Azure 是一个开放.灵活的云平台,可支持大量且不断增长的开源应用程序.框架和语言.微软及微软开放技术通过与全球及中国本地的开源社区不懈地合作,将 ...

  5. MVVM模式应用体会

    转自:http://www.cnblogs.com/626498301/archive/2011/04/08/2009404.html 进公司实习工作后,本人接触的第一个技术名语就是MVVM模式,从学 ...

  6. Asp.Net 前后台交互小结

    转自:http://blog.csdn.net/wlccomeon/article/details/17270427 一.前台调用后台           前台调用后台的方法一共可分为两大类:使用Ht ...

  7. ASPNET5中的那些K

    ASPNET5中的那些K ASP.NET 5最大的变化是什么?首当其冲的就是多了很多K,K表示的是ASP.NET vNext的项目代号“Project K”,但很容易让人想到一个汉字——“坑”,希望K ...

  8. 编程之美 两个叶子的节点之间 最大距离 变种 leecode

    提交地址: https://oj.leetcode.com/problems/binary-tree-maximum-path-sum/ 说一下思路http://www.cnblogs.com/mil ...

  9. windows下Qt5.1 for android开发环境配置(PS:Qt5.2出来了哈,稳定)

    说明:以下开发环境配置过程参考了这些文章: http://qt-project.org/wiki/building_qt-android_on_windows http://www.hyarm.com ...

  10. Tsinsen A1505. 树(张闻涛) 倍增LCA,可持久化线段树,DFS序

    题目:http://www.tsinsen.com/A1505 A1505. 树(张闻涛) 时间限制:1.0s   内存限制:512.0MB    总提交次数:196   AC次数:65   平均分: ...