python-day3

day3 上课所讲内容:
3.1 集合操作
 集合是一个无序的,不重复的数据组合,它的主要作用如下:
  •去重,把一个列表变成集合,就自动去重了
  •关系测试,测试两组数据之前的交集、差集、并集等关系
 常用操作:
 ss = set([2,3,4]) #创建一个数值集合
 tt = set("Hello") #创建一个唯一字符的集合
 a = tt | ss  # tt 和 ss 的并集
 b = tt & ss  # tt 和 ss 的交集
 c = tt - ss  # 求差集在tt中,但不在ss中
 d = tt ^ ss  # 对称差集 在tt和ss中,但不会出现在二者中
 基本操作:
 tt.add('x')  # 添加一项
 ss.update([10,15,30]) # 在s中添加项
 tt.remove('o')  # 删除一项
 len(ss)   # ss的长度
 x in ss   # 测试x是否是s的成员
 ss.copy()  # 浅复制
3.2 文件操作
 Python 提供了必要的函数和方法进行默认情况下的文件基本操作。你可以用 file 对象做大部分的文件操作。
 open 函数
  你必须先用Python内置的open()函数打开一个文件,创建一个file对象,相关的方法才可以调用它进行读写。
  语法:
   file object = open(file_name [, access_mode][, buffering])
   各个参数的细节如下:
   file_name:file_name变量是一个包含了你要访问的文件名称的字符串值。
   access_mode:access_mode决定了打开文件的模式:只读,写入,追加等。所有可取值见如下的完全列表。这个参数是非强制的,默认文件访问模式为只读(r)。
   buffering:如果buffering的值被设为0,就不会有寄存。如果buffering的值取1,访问文件时会寄存行。如果将buffering的值设为大于1的整数,表明了这就是的寄存区的缓冲大小。如果取负值,寄存区的缓冲大小则为系统默认。
  不同模式打开文件的完全列表:
  模式 描述
  r 以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。
  rb 以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。
  r+ 打开一个文件用于读写。文件指针将会放在文件的开头。
  rb+ 以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。
  w 打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
  wb 以二进制格式打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
  w+ 打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
  wb+ 以二进制格式打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
  a 打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
  ab 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
  a+ 打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。
  ab+ 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。
 File对象的属性
  一个文件被打开后,你有一个file对象,你可以得到有关该文件的各种信息。
  以下是和file对象相关的所有属性的列表:
  属性 描述
  file.closed 返回true如果文件已被关闭,否则返回false。
  file.mode 返回被打开文件的访问模式。
  file.name 返回文件的名称。
  file.softspace 如果用print输出后,必须跟一个空格符,则返回false。否则返回true。
 close()方法
  File 对象的 close()方法刷新缓冲区里任何还没写入的信息,并关闭该文件,这之后便不能再进行写入。
  当一个文件对象的引用被重新指定给另一个文件时,Python 会关闭之前的文件。用 close()方法关闭文件是一个很好的习惯。
  语法:
  fileObject.close();
 write()方法
  write()方法可将任何字符串写入一个打开的文件。需要重点注意的是,Python字符串可以是二进制数据,而不是仅仅是文字。
  write()方法不会在字符串的结尾添加换行符(' '):
  语法:
   fileObject.write(string);
 read()方法
  read()方法从一个打开的文件中读取一个字符串。需要重点注意的是,Python字符串可以是二进制数据,而不是仅仅是文字。
  语法:
  fileObject.read([count]);
  在这里,被传递的参数是要从已打开文件中读取的字节计数。该方法从文件的开头开始读入,如果没有传入count,它会尝试尽可能多地读取更多的内容,很可能是直到文件的末尾。
 tell()方法告诉你文件内的当前位置;换句话说,下一次的读写会发生在文件开头这么多字节之后。
 seek(offset [,from])方法改变当前文件的位置。Offset变量表示要移动的字节数。From变量指定开始移动字节的参考位置。
 重命名和删除文件
  Python的os模块提供了帮你执行文件处理操作的方法,比如重命名和删除文件。
  要使用这个模块,你必须先导入它,然后才可以调用相关的各种功能。
  rename()方法:
  rename()方法需要两个参数,当前的文件名和新文件名。
  语法:
  os.rename(current_file_name, new_file_name)
 remove()方法
  你可以用remove()方法删除文件,需要提供要删除的文件名作为参数。
  语法:
  os.remove(file_name)
3.3函数
 定义一个函数:
  你可以定义一个由自己想要功能的函数,以下是简单的规则:
  函数代码块以 def 关键词开头,后接函数标识符名称和圆括号()。
  任何传入参数和自变量必须放在圆括号中间。圆括号之间可以用于定义参数。
  函数的第一行语句可以选择性地使用文档字符串—用于存放函数说明。
  函数内容以冒号起始,并且缩进。
  return [表达式] 结束函数,选择性地返回一个值给调用方。不带表达式的return相当于返回 None。
 特性:
  1.减少重复代码
  2.使程序变的可扩展
  3.使程序变得易维护
 参数
  以下是调用函数时可使用的正式参数类型:
   必备参数
   关键字参数
   默认参数
   不定长参数
  必备参数:
  必备参数须以正确的顺序传入函数。调用时的数量必须和声明时的一样。
  调用函数,你必须传入一个参数,不然会出现语法错误。
  关键字参数
  关键字参数和函数调用关系紧密,函数调用使用关键字参数来确定传入的参数值。
  使用关键字参数允许函数调用时参数的顺序与声明时不一致,因为 Python 解释器能够用参数名匹配参数值。
  以下实例在函数调用时使用参数名:
 全局与局部变量

  在子程序中定义的变量称为局部变量,在程序的一开始定义的变量称为全局变量。
  全局变量作用域是整个程序,局部变量作用域是定义该变量的子程序。
  当全局变量与局部变量同名时:
  在定义局部变量的子程序内,局部变量起作用;在其它地方全局变量起作用。

原文地址:https://www.cnblogs.com/xiaopeng01/p/5760774.html