Day-11 - 文件操作(2018-10-14)

一、模块的使用

1. 模块使用说明

python中一个py文件就是一个模块,
可以通过import 或者 from - import在一个模块中去使用另一个模块的内容

  • import 模块名
    ---> 将模块中所有的内容都导入,并且可以在当前模块中通过“模块名.”的方式去使用所有的全局变量
    (推荐,可以从代码中看出来是从哪个模块中导入的)

  • from 模块名 import 变量1,变量2,……
    --> 将模块中所有的内容都导入,但是只能使用import后面的变量

  • from 模块名 import *
    --> 将模块中所有的内容都导入,可以直接使用模块中所有的变量

代码执行到import的时候,会将import后面的模块的内容执行一遍

例:

# import test1
# # 100
# # 这是test1中的内容
# # hello test1
#
# print(test1.test_a + 1)  # 101
# test1.test1_func1()  # hello test1

test1.py中代码如下:

test_a = 100
print(test_a)

print('这是test1中的内容')


def test1_func1():
    print('hello test1')


test1_func1()
# from test1 import test_a
# print('当前模块:', test_a)
# print('当前模块:', test_func1)  # NameError: name 'test_func1' is not defined

# from test1 import test1_func1, test_a
# # 100
# # 这是test1中的内容
# # hello test1
#
# test1_func1()  # hello test1

# from test1 import *
# # 100
# # 这是test1中的内容
# # hello test1
# test1_func1()  # hello test1

2.重命名

import 模块吗 as 模块的新名字 (给模块重命名,使用的时候使用新的名字)
from 模块名 import 变量名1 as 新名1, 变量名2,…… (给部分变量重新命名)

# import test1 as TS
# # 100
# # 这是test1中的内容
# # hello test1
#
# TS.test1_func1()  # hello test1

# from test1 import test_a as ts_a
# test_a = 50
# # 100
# # 这是test1中的内容
# # hello test1
# print(ts_a + 1)  # 101 (使用test1模块的test_a变量)
# print(test_a)  # 50 (当前模块的test_a变量)

3.import:

可以检查被导入的内容之前是否已经导入过,如果导入过,不会再重复导入,但是多种导入的效果可以同时生效

# 导入多次,但是只执行一次,多种导入的效果可以同时生效
# import test1
# import test1
# from test1 import test1_func1 as ts_a
# # 100
# # 这是test1中的内容
# # hello test1
#
# test1.test1_func1()  # hello test1
# ts_a()  # hello test1

二、选择性导入(阻止导入)

1.阻止导入的方法:

if __name__ == ‘__main__':
代码块

说明:
if __name__ == ‘__main__': --> 固定写法
代码块 --> 直接执行当前模块,代码块会被执行,如果在别的模块中被导入,代码块不会执行

test1.py中代码:

def test1_func1():
    print('hello test1')


if __name__ == '__main__':
    test_a = 100
    print(test_a)
    print('这是test1中的内容')
    test1_func1()
import test1
# 没有打印
test1.test1_func1()  # hello test1
# test1.test_a在阻止导入代码块中,不会导入
# print(test1.test_a)  # AttributeError: module 'test1' has no attribute 'test_a'

2.阻止导入语句的原理

每一个模块都有一个 name 属性,这个属性的默认值是当前模块对应py文件的文件名,
当当前模块正在被执行(直接)的时候,系统会自动将模块的name属性变成'main'

import test1

print(__name__)  # __main__

print(test1.__name__)  # test1


3.什么时候使用模块

将具有相同的功能的函数和数据封装到一起

三、迭代器

1.什么是迭代器(iter)

迭代器是python中一种容器类的数据类型,属于序列。没有具体的字面量,
可以将其他的序列转换成迭代器: iter(序列)

2.迭代器的特点

只能通过next方法去一个一个地按顺序获取迭代器中的元素,取出后迭代器中就不存在这个元素了


print(iter([5, 6, 7]))  # <list_iterator object at 0x00000000025EB2B0>

iter1 = iter('abc')
print(iter1)  # <str_iterator object at 0x00000000024E28D0>
print(next(iter1))  # a
print(next(iter1))  # b
print(next(iter1))  # c
# print(next(iter1))  # StopIteration

3.遍历迭代器

print('===============')
iter1 = iter(['abc', 1, 'name'])

for x in iter1:
    print(x)
# abc
# 1
# name

next(迭代器)
迭代器.next()


iter2 = iter((1, 2, 3))
a = iter2.__next__()
print(a)  # 1
print(next(iter2))  # 2
list1 = list(iter2)
print(list1)  # [3]

四、生成式和生成器

1.什么是生成器

生成器就是迭代器,但是迭代器不一定是生成器

生成式就是生成器的一种特殊形式:(变量 for 变量 in 序列)

例:产生一个生成器,生成器中可以生成的数据是数字0~4(每个元素是数字)

ge1 = (x for x in range(5))
print(ge1)

print(next(ge1))
print(next(ge1))

print('=========')
for item in ge1:
    print(item)

ge2 = (x*2 for x in range(5))
print('=========')
for item in ge2:
    print(item)


ge2 = ([x, x*2] for x in 'abc')
print(next(ge2))

print('===========')
ge2 = (x for x in range(5) if x%2)

for item in ge2:
    print(item)

2.生成器就是函数体中有yield关键字的函数

--> (函数中只要有yield,那么调用这个函数不再是执行函数体并且获取返回值,而是产生一个生成器)

通过next获取生成器的元素的时候,会去执行生成器对应的函数的函数体,执行到yield为止,并且将yield后面的值作为返回值(元素值)。
然后保存当前结束的位置,下次一获取生成器的元素的时候会接着上次结束位置往后执行,执行到yield.....

生成器可以当成序列来使用


print('============')
def func1(n):
    print('你好,生成器!!')
    for x in range(n+1):
        print(x)
        yield x
        print('yeye')


ge3 = func1(3)
print(ge3)

print('=:',next(ge3))  #    0
print('=:',next(ge3))  # 1
print(next(ge3))  #  2
print(next(ge3))  # 3
# print(next(ge3))


def func2():
    str1 = 'abcdef'
    index = 0
    while index < len(str1):
        yield str1[index]
        index += 1

ge4 = func2()

print(next(ge4))
#
print(next(ge4))
print(list(ge4))


def func3():
    num = 0
    while True:
        yield num
        num += 1

ge5 = func3()
print(ge5)
print('==:',next(ge5))
print('==:',next(ge5))

print('========')
for _ in range(5, 100):
    print(next(ge5))

print('=======')
print(next(ge5))

练习: 生成器生成的数据的规律:奇数就返回他本身,偶数就返回它的2倍

def func2(n):
    for x in range(n):
        yield x, 2*x, 3*x
        # yield 2*x
        # yield 3*x
        # if x%2:
        #     yield x
        # else:
        #     yield x*2

g6 = func2(5)
print(next(g6))
print(next(g6))
print(next(g6))

五、文件的读写

使用文件可以做数据的持久化(本地化) ---> 数据库文件,txt、json,plist,二进制文件

1.文件操作 -- 读写操作

读 -> 取出文件中的数据
写 -> 将数据写到文件中

所有文件操作的过程:打开文件 --> 操作文件 --> 关闭文件

2.打开文件和关闭文件

open(file, mode='r',encoding=None)

  • a. file -> 文件路径(必须传参),决定需要打开的是哪个文件
    绝对路径(不推荐使用)
    相对路径: ./相对路径 (相对路径是相对当前py文件对应的文件夹)
    ./ ---> 当前文件夹
    ../ --> 当前文件夹的上层文件夹
    .../ --> 当前文件夹的上层文件夹的上层文件夹

  • b. mode -> 文件打开方式(不同的操作对应不同的打开方式)
    'r' --> 以只读的形式打开文件, 文本
    'rb'/'br' --> 读操作,读出来的数据是二进制形式的数据
    'w' --> 以写的形式打开文件
    'bw'/'wb' --> 写操作,将二进制数据写入文件
    'a' --> 写操作,追加

  • c. encoding -> 文本文件的编码方式
    utf-8 :几乎支持所有的语言文字
    gbk : 只支持英文

  • d. open函数的返回值,就被打开的文件对象

关闭文件: 文件对象.close()

========================文件的读操作=====================

  1. 打开文件
f1 = open('./test1.txt', 'r', encoding='utf-8')
  1. 读文件中的内容

文件对象.read() --> 从文的读写位置读到文件结束,返回读到的结果
文件对象.readline() --> 读一行
文件对象.readlines() --> 返回一个列表,列表的元素是文件中每一行的内容

content = f1.read()
print(type(content), content)

# print('==:', f1.read())

# content = f1.readlines()
# print(content)
  1. 关闭文件
f1.close()

** ==================文件的写操作==================**

  1. 打开文件

'w' -> 将字符串写入文件中, 完全覆盖文件原来的内容
'wb'/'bw' -> 将二进制写入文件中, 完全覆盖文件原来的内容
'a' -> 追加

f2 = open('./test1.txt', 'w', encoding='utf-8')
  1. 写入文件
f2.write(content+'hello world')  # 这样写可以接着之前读取的内容写
f2.writelines(['abc\n', '123\n', 'aaaaa\n'])  # 覆盖写
  1. 关闭文件
f2.close()
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,793评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,567评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,342评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,825评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,814评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,680评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,033评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,687评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,175评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,668评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,775评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,419评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,020评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,206评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,092评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,510评论 2 343

推荐阅读更多精彩内容

  • 1. recode 1. 匿名函数 格式:lambda 参数列表: 返回值 常用情况:函数名 = lambda...
    EryangZ阅读 106评论 0 0
  • 我出生在一个交通不太便利的小村庄,自己小时候的童年,在温饱还是问题的情况下,别说是看动画片了,连个自己的玩具...
    永往只前阅读 521评论 0 0
  • 除夕的鞭炮声里 团圆的梦咒 正月的锣鼓 唤起远古的记忆 玄玄的社火 元宵烟花的美丽 古庙小曲化清音 河谷东风雨霏霏...
    陇右行思阅读 268评论 0 5
  • 关键数据 内容:用户创建的数据文件,无法再删除后自动重新创建 路径:主目录/Documents 属性:不要设置"不...
    小羊孩子阅读 1,295评论 0 1
  • 今天由王老师的智能扫地机器人开启了我们新的一天,首先这款智能机器人叫星光,型号是770W,它的外壳是可以更换的,而...
    君君_aa1f阅读 186评论 0 0