python day 3

1.文件处理

1 f = open(‘1.txt‘,‘r‘,encoding=‘utf-8‘)
2
3 with open(‘1.txt‘,‘r‘,encoding=‘utf-8‘) as f:
4     print (f.read())

流程分析:
 1.向操作系统发起系统调用
 2.操作系统打开文件,返回一个文件句柄给应用程序
 3.在应用程序中把文件句柄赋值给一个变量

1 注意两点:
2   1.打开一个文件定义两部分,一个是python级别的文件句柄,另一个是操作系统打开的文件(默认)
3      打开文件的编码是以操作系统的编码为准,除非open()指定编码
4   2.当文件操作完毕后,应该回收两部分资源
5      del f :回收应用程序资源(python解释器字典的垃圾回收机制已经替我们做了)
6      f.close()回收操作系统

4.文件的打开模式

 1   r :默认的打开模式,只读,文件不存在则报错
 2   f.read() 读取文件的所有内容
 3   f.readline() 一次读一行
 4    print(readline(),end=‘‘)不读取换行符
 5   f.readlines() 读所有,结果放入列表
 6
 7   w :只写模式,如果文件存在则清空,如果文件不存在则创建
 8   f= open(‘1.txt‘,‘w‘,encoding=‘utf-8‘)
 9   f.write(‘1111\n‘)
10   f.writelines()写入多行
11
12   a :追加写模式,如果文件不存在则新建,存在则把光标移动到问及那末尾
13   f= open(‘1.txt‘,‘a‘,encoding=‘utf-8‘)
14   f.write(‘1111\n‘)
15   f.writelines()写入多行   rb : 以bytes的形式去操作文件内容,不能指定编码  f = open(‘1.jpg‘,‘rb‘)

5.bool值:所有的数据类型都自带布尔值

  布尔值为假的情况:0,空 ,None

6.文件修改
 #方式一:把硬盘中文件的数据全部读到内存,然后再内存中修改,然后保存
 #方式二:一行一行的读,一行一行的改

2.函数

基础函数:

1  1.组织结构混乱,可读性差
2  2.代码冗余
3  3.无法统一管理,维护难度大
4  函数的使用必须遵循:先定义,后调用

3.函数分类:

1 内置函数:python 解释器自带的函数,python解释器启动就会定义好
2  自定义函数:
3   1.函数的使用必须遵循:先定义,后调用
4   2.函数的定义,就相当于在定义一个变量,如果没有定义
5  语法:
6   def 函数名(参数1,参数2,.....):
7    ‘‘‘注释‘‘‘
8    函数体
9    return  返回值
定义函数阶段:
函数在定义阶段,只检测语法,不执行代码
    1.无参:函数体不需要外部的值
    2.有参:函数体的代码,需要外部的值
        def my_max(x,y):
            if x > y:
                return x
            else:
                return y
        res = my_max(10,20)

    3.空函数:
        def foo():
            pass
 1 调用函数阶段:
 2  1.函数名()
 3  需要注意:通过名字找到函数的内存地址,然后加括号调用
 4  2.函数的返回值return
 5   在调用函数的过程中,一旦执行return,就会立刻终止函数,并且把return后的结果当做本次的返回值返回
 6   函数体内可以有多个
 7  注意第二点:
 8   返回的值,可是任意类型
 9  注意第三点:
10   没有return ,默认返回None
11   可以返回一个值(类型是值的类型)
12   可以用逗号分隔,返回多个值==元组的类型

3.调用函数的三种形式:

1 def foo():
2    print (‘1111‘)
3    return 123
4 foo()
5   name = foo()
6   name = foo()*10 等于 name = 23 * 10

4.形参与实参

形参:在函数定义阶段,括号内定义的参数成为形参,就相当于变量名

实参:在函数调用阶段,括号内定义的参数称为实参,就相当于变量值
在调用阶段,实参的值会绑定给形参,在调用结束后,解除绑定

5.参数的分类

1.位置参数:
            位置形参:必须被传值得参数,多一个不行,少一个也不行
            位置实参:从左到右依次赋值给形参
        2.关键字参数:在函数调用阶段按照key=value的形式定义实参
                      可以不依赖位置而指名道姓的给形参传值
                      需要注意的问题(可以与位置实参混用:但是)
                      1.位置实参必需在关键字实参的前面
                      2.不能为一个形参重复传值

            def foo(x,y):
                print (x,y)

            foo(y=1,x=2)
        3.默认参数:在函数的定义阶段,已经为形参赋值了,在定义阶段已经赋值,意味着在调用可以不传值
            def foo(x,y=10):
                print(x,y)
            foo(1)
            注意的问题:
                1.默认参数的值,只在定义是赋值一次
                2.位置形参应该在默认参数的前面(def foo(x,y=2,c))这样都是错误的
                3.默认参数的值应该是不可变类型
        4.可变长参数
            实参可变长度指的是:实参的个数是不固定的
            而实参的定义形式无非两种:1、位置实参 2、关键字实参
            针对这两种形式的实参个数不固定,相应的,形参也要有两种解决方案
            针对位置实参溢出的部分实参,*args
            def  func(x,y,*args): #args=(3,4,5,6,7)
                print (x,y,args)

            l = [1,2,3,4,5,6,7]
            func(*l)
            针对按照关键字定义的溢出的那部分实参,形参:**args
            def foo(x,y,**args): # args = {‘a‘:1,‘b‘:2}
                print(x,y,args)
            foo(1,2,3,**{‘a‘:1,‘b‘:2})
        5.命名关键字参数(了解):形参中,在*后定义的参数称之为命名关键字参数
            他的特性是:传值时,必须按照关键字实参的形式传值
            def foo(x,y,*,a,b):

        位置参数,默认参数,*args ,命名关键字参数

3.函数对象

 1     函数的嵌套调用
 2     def
 3     函数的嵌套定义:在定义一个函数内部,又定义了一个函数
 4     def f1():
 5         def f2():
 6             def f3():
 7                 print (‘11111‘)
 8             f3()
 9         f2()
10     f1()

4.名称空间与作用域

 1     1.名称空间:存放名字与值绑定关系的空间
 2         全局名称空间
 3             存放的是:文件级别定义的名字与值的绑定关系
 4             生效:执行python文件时,以该文件级别定义的名字与值的绑定古纳西
 5             失效:文件执行完毕
 6         局部名称空间
 7             存放的是:函数内部定义的名字与值的绑定关系
 8             生效:调用函数时,临时生效
 9             失效:函数调用结束
10         内置名称空间
11             存放的是:内置的名字与值得绑定关系
12             生效:python  解释器启动
13             失效:python 关闭
14         加载顺序:
15             先内置,再全局,最后局部
16         查找名字的顺序:
17             先局部,再全局,最后内置
18     2.作用域:
19         全局作用域:包含内置名称空间的名字与全局名称空间的名字
20                     全局存活,全局有效
21         局部作用域:包含局部名称空间的名字
22                     临时存活,局部有效
23     作用域关系,在函数定义是,就已固定了,与调用无关
24     global   声明内部变量是全局变量
25         def f1():
26             global x
27             x = 1
28     nonlocal x    
时间: 2024-10-12 11:51:30

python day 3的相关文章

Python学习1-Python和Pycharm的下载与安装

本文主要介绍Python的下载安装和Python编辑器Pycharm的下载与安装. 一.Python的下载与安装 1.下载 到Python官网上下载Python的安装文件,进入网站后显示如下图: 网速访问慢的话可直接在这里下载:python-2.7.11.amd64 在Downloads中有对应的支持的平台,这里我们是在Windows平台下运行,所以点击Windows,出现如下: 在这里显示了Python更新的所有版本,其中最上面两行分别是Python2.X和Python3.X对应的最后更新版本

Python——深入理解urllib、urllib2及requests(requests不建议使用?)

深入理解urllib.urllib2及requests            python Python 是一种面向对象.解释型计算机程序设计语言,由Guido van Rossum于1989年底发明,第一个公开发行版发行于1991年,Python 源代码同样遵循 GPL(GNU General Public License)协议[1] .Python语法简洁而清晰,具有丰富和强大的类库. urllib and urllib2 区别 urllib和urllib2模块都做与请求URL相关的操作,但

python学习_day26_面向对象之封装

1.私有属性 (1)动态属性 在python中用双下划线开头的方式将属性隐藏起来.类中所有双下划线开头的名称,如__x都会自动变形成:_类名__x的形式.这种自动变形的特点是: a.类中定义的__x只能在内部使用,如self.__x,引用的就是变形的结果.b.这种变形其实正是针对外部的变形,在外部是无法通过__x这个名字访问到的.c.在子类定义的__x不会覆盖在父类定义的__x,因为子类中变形成了:_子类名__x,而父类中变形成了:_父类名__x,即双下滑线开头的属性在继承给子类时,子类是无法覆

python面向对象知识点疏理

面向对象技术简介 类: 用来描述具有相同的属性和方法的对象的集合.它定义了该集合中每个对象所共有的属性和方法.对象是类的实例.class 类变量:类变量在整个实例化的对象中是公用的.类变量定义在类中且在函数体之外.类变量通常不作为实例变量使用. 数据成员:类变量或者实例变量用于处理类及其实例对象的相关的数据. 方法重写:如果从父类继承的方法不能满足子类的需求,可以对其进行改写,这个过程叫方法的覆盖,也称为方法的重写. 实例变量:定义在方法中的变量,只作用于当前实例的类. 继承:即一个派生类(de

python实现网页登录时的rsa加密流程

对某些网站的登录包进行抓包时发现,客户端对用户名进行了加密,然后传给服务器进行校验. 使用chrome调试功能断点调试,发现网站用javascript对用户名做了rsa加密. 为了实现网站的自动登录,需要模拟这个加密过程. 网上搜了下关于rsa加密的最简明的解释: rsa加密是非对称加密算法,该算法基于一个十分简单的数论事实:将两个大素数相乘十分容易,但那时想要对其乘积进行因式分解却极其困难,因此可以将乘积公开作为加密密钥,即公钥,而两个大素数组合成私钥.公钥是可发布的供任何人使用,私钥则为自己

Python中编码的详细讲解

看这篇文章前,你应该已经知道了为什么有编码,以及编码的种类情况 ASCII 占1个字节,只支持英文 GB2312 占2个字节,支持6700+汉字 GBK GB2312的升级版,支持21000+汉字 Shift-JIS 日本字符 ks_c_5601-1987 韩国编码 TIS-620 泰国编码 由于每个国家都有自己的字符,所以其对应关系也涵盖了自己国家的字符,但是以上编码都存在局限性,即:仅涵盖本国字符,无其他国家字符的对应关系.应运而生出现了万国码,他涵盖了全球所有的文字和二进制的对应关系, U

Python练习(一)

Python练习(一): 给一个不超过5位的正整数,判断其有几位,依次打印出个位.十位.百位.千位.万位的数字: num = int(input('please enter a number: '))   lst = [] for i in str(num):      lst.append(i) lenlst = len(lst) if num >= 1000:      if num >= 10000:          print('too big')     else:        

菜鸟学python之对象类型及运算

Python 中的变量不需要声明.每个变量在使用前都必须赋值,变量赋值以后该变量才会被创建. 在 Python 中,变量就是变量,它没有类型,我们所说的"类型"是变量所指的内存中对象的类型. 等号(=)用来给变量赋值. 1 变量赋值 1.1 单个变量赋值 >>> name="python" >>> print(name) python 1.2 多个变量赋值 >>> name=names="python&

开始我的Python爬虫学习之路

因为工作需要经常收集一些数据,我就想通过学爬虫来实现自动化完成比较重复的任务. 目前我Python的状况,跟着敲了几个教程,也算是懂点基础,具体比较深入的知识,是打算从做项目中慢慢去了解学习. 我是觉得如果一开始就钻细节的话,是很容易受到打击而放弃的,做点小项目让自己获得点成就感路才更容易更有信心走下去. 反正遇到不懂的就多查多问就对了. 知乎上看了很多关于入门Python爬虫的问答,给自己总结出了大概的学习方向. 基础: HTML&CSS,JOSN,HTTP协议(这些要了解,不太需要精通) R

解决:Elipse配置Jython Interpreters时报错Error: Python stdlib source files not found

今天学习lynnLi的博客monkeyrunner之eclipse中运行monkeyrunner脚本之环境搭建(四)时,遇到了一个问题,即: lynnLi给出的解决办法是:将Python下的Lib拷贝到sdk中jython-standalone-2.5.3.jar所在目录tools\lib,再次New一个Jython,添加jython-standalone-2.5.3.jar路径即可 但是这样尝试,又报错了: 后来借鉴了这篇文章的做法,成功配置Jython Interpreters: 将\sdk