热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

python基础笔记(非系统/自用/参考小甲鱼的零基础入门学习python)上

---恢复内容开始---1.原始字符串的使用,在字符串前加r就行(用于对\进行自动转译)>>>strrC:\now\wifrC:\\now\\wifr

---恢复内容开始---

1.原始字符串的使用,在字符串前加r就行(用于对\进行自动转译)

  >>>str = r'C:\now\wifr'
  'C:\\now\\wifr'
  但在字符串后面不能有空的'\'
  >>>str = r'C:\now\wirf\'
  error
  长字符串的使用,用""" """将字符串包起来
  >>>str = """ xsf,
       xfasf,
        sdasdas"""
  'xsf,\nxfasf,\nsdasdas\n'
(会自动给回车处加\n)

2.isinstance(变量,类型):用于判断该变量是否为该类型,返回t/f

   id(变量名):用于查看变量的地址

   dir([]):不带参数时,返回当前范围内的变量、方法和定义的类型列表;带参数时,返回参数的属性、方法列表

3.在变量命名时,不能与系统BIF重名,否则会时原BIF函数无法使用

4.python2版本整形除法‘/’采用地板规则,向下取整,python3版本则保留小数,有‘//'运算负责采用地板规则,‘**’为幂运算(eg:2**3=8)

5.幂运算符,比起左侧的一元运算符优先级高,比起右边的一元运算符优先级低(eg:  -3**2=-9 => -<** =>-(3**2)  3**-1=1/3 => **<- =>3**(-1))

(一元操作符:只有一个操作数的运算符  二元操作符:两个操作数)

6.python允许a

7.运算符优先级:**>正负>加减乘除>大于小于等于>and or not

8.python允许esif(等同于else if )if else 搭配比多个if好

9.python的三元操作符: x if 布尔 else y 等同于C的 布尔?x:y

10.断言assert:当assert关键字后边的条件为假的时候,程序自动崩溃并抛出AssertionError异常

  >>>assert 3>4

   AssertionError

作用:一般来说我们可以用该关键字在程序中置入检查点,当需要确保程序中的某个条件一定为真才能让程序正常工作的话,assert关键字就非常有用了

11.python的for循环可以直接调用迭代器的next方法,会自动的捕获stoplteration异常,自动结束循环

语法:for 变量 in 表达式(也可以是文件):

          循环体

eg:>>>for i in 'wocao':

      print(i,end = ' ')

  w o c a o 

for常与range(start,stop,step)搭配(start(可有可无,无则从零开始)到stop-1,step是间隔,step为2,则类似1,3,5.。。)

eg:>>>for i in range(5):

      print(i)

  0/n1....4

12.列表(跟数组差不多,但可混可空)。添加可用append()只能添加一个eg:列表名.append(xxx);也可以用exend([,]),可添加多个eg:列表名.extend([xxx,xxxx])。指定位置添加用insert(添加位置,添加内容)。

删除用remove(具体内容),或del 列表名[下标](del也可直接将整个列表删除);因为python的列表是用栈(数据结构)来存储的,所以也可以用pop(索引可有可无)来将栈顶(列表最后)元素弹出

列表分片:列表名[x:y];列表与列表的比较:以首元素为准;列表*int:将列表复制3次存进列表中;判断元素是否在列表中,用in(只能判断同一层) eg:xxx in listname 返回t/f,对于listname[xxx,[xxxx,xx],x]   xxxx in listname return False | xxxx in listname[1](嵌套列表所在下标) return True

listname.reverse():翻转列表      listname.sort(func=排序算法默认归并,key=算法搭配的关键字,reverse=t/f默认f):排序

列表复制:1. listname1=listname[:](分片) 两个指向不同的内存地址,只是内容一样,所以原列表改变不影响listname1

     2. listname2=listname 两个指向同一个内存地址,当原列表发生改变时,listname2也会改变

13.元组tuple(不可变位,不可重新赋值的list):声明一个元组,tuplename=(,,,,)关键是','  tuplename=8, 元组 tuplename=(8) int   2*(8)=16 2*(8,)=(8,8) 

添加元素(通过切片的方式):tuplename=tuplename[:添加位]+(添加的元素,)+tuplename[添加位:]

14.字符串拼接用+,并不是改变原来的字符串,而是将拼接后的字符串贴上一样的标签,原来的字符串会被释放

15.判断字符串是否为数字可用isdigit()、isnumeric()、isdecimal()方法,三者的区别如下

isdigit()

True: Unicode数字,byte数字(单字节),全角数字(双字节),罗马数字
False: 汉字数字
Error: 无

isdecimal()
True: Unicode数字,,全角数字(双字节)
False: 罗马数字,汉字数字
Error: byte数字(单字节)

isnumeric()
True: Unicode数字,全角数字(双字节),罗马数字,汉字数字
False: 无
Error: byte数字(单字节)

16.format()方法

17.声明函数:def func_name(xxx='默认值可有可无',xxxx='默认值可有可无',*xxxxx可变(参数个数无限,原理是打包成元组)参数):

        'xxxxx函数文档,用func_name.__doc__可调出来看,不调用则不显示'

        #注释

                       函数体

*args为任意的参数,通过下面代码将这些参数写进列表中

 关键词参数:在调用函数时,传参使用 形参名='实参' 可避免实参顺序错乱导致结果与预期不符 eg:func_name(name='比企谷彩羽’,xxx='xxxx')

python可以返回多个值(以列表或元组的形式)

18.过程:没有返回值的函数

19.在试图在函数内部修改全局变量时,python隐蔽机制会在函数中创建一个名字一模一样的局部变量,从而使修改的结果是修改了局部变量,全局变量不变

但可以通过global关键字在函数内修改全局变量    

20.内部函数(嵌套函数):在函数体里面再声明一个函数,在外层函数体内可以任意的调用内部函数,但出了外层函数,则不能对内部函数直接进行调用

21.闭包:闭包是由函数及其相关的引用环境组合而成的实体(即:闭包=函数+引用环境)(想想Erlang的外层函数传入一个参数a, 内层函数依旧传入一个参数b, 内层函数使用a和b, 最后返回内层函数)

.

将外层函数看为全局,则在外层函数里声明的变量对于内层函数来说就相当于全局变量,所以试图在内层函数修改外层函数变量时,python会将外层变量屏蔽起来,系统就会报错:

解决方法:python3之后,可以同过nonlocal关键字来解决,而python2则需同过将外层函数变量声明成容器(list,tuple,str,...),因为容器不是存放在栈里面 

容器:nonlocal关键字:  

22.匿名函数:使用lambda关键字声明函数,调用时直接赋值给某个变量就行,当匿名函数不使用时,python的垃圾回收机制会将该函数清理掉

其中x为参数,参数可有多个

23.两个值得认识的BIF:过滤器filter(function or None,iterable迭代器列表之类的)将迭代器中True的抽取出来

自己写过滤规则,下面的是将偶数过滤

function参数只需将函数名传给filter(),左=右

映射map(function,iterable)将iterable根据function进行加工,eg:

24.python系统默认的递归(recursion)深度是100层,想要自定义递归深度,需

>>>import sys

>>>sys.setrecursionlimit(deepth)

25.字典dict(key->value):字典的标志性符号为{ } eg:

dictname = {key1:value1, key2:value2,...}

声明之后就可以通过key来索引对应的value:x = dictname[key1]   ==> x == value1

 字典常用方法:

fromkeys(...)  --> dict.fromkeys(S[,v]) -> new dict with keys from S and values equal to v(v defaults to None)

keys() --> dict.keys() 将字典中的key抽出来,常用于for  -->  for each in dictname.keys()

values() -->dict.values() 将字典中的vaules抽出来,常用于for  -->  for each in dictname.values()

items() -->dict.items() 将字典中的(key,value)组合抽出来,常用于for  -->  for each in dictname.items()

keys():values():items():

 

 get()-->dict.get(key)获取value,比直接dict[key]灵活,当dict[key]不存在时系统会报错,而get(key)则会返回一个None来免程序报错

 

clear()-->dict.clear()将字典清空

copy()-->dict.copy()复制字典--> dict2 = dict1.copy() 跟dict3 = dict1的效果一样,但dict2所在的地址于dict1不同,而dict3与dict1指向同一个地址

26.成员资格操作符:in 和 not in   -->  用来判断某元素是否存在于某容器中(list,字典,str,tuple...) eg:xxx in xxxx  返回t/f

27.集合(set):集合中的元素是不重复的。创建:直接把一堆元素用花括号括起来;或用set([,,,,])工厂函数来创建

 直接用花括号声明时,没有键值对的为集合,有则为字典;集合会将重复的值去除;集合无法用下标索引

不可变集合(frozenset):不能增删改

28.打开文件(open):open(file, mode = '打开模式默认r', buffering = 1, encoding = None, newline = None, closefd = True, opener = None)

在使用write()或writeline()方法时,打开模式需为'w'或‘a',w会覆盖原来的内容,a则在原内容的末尾添加新内容

若通过open创建了文件没有执行filename.close()操作,写入的内容将不被保存

with 语句适用于对资源进行访问的场合,确保不管使用过程中是否发生异常都会执行必要的“清理”操作,释放资源,比如文件使用后自动关闭/线程中锁的自动获取和释放等。

29.常用模块: os模块、os.path模块(是处理出来的模块,使用os.path.function)、time模块、

pickle模块(将对象转换成二进制存储)   

pickle_file = open(’文件名.pkl','注意用wb模式) #创建用来保存二进制的文件,w为写b指二进制wb对应读就是rb   

pickle.dump(想要保存的对象,pickle_file) #将对象倒进去

pickle_file_load = open(open创建的文件名,'rb模式') #打开二进制文件

xxxx = pickle.load(pickle_file_load) #将二进制文件转成对象

30.try - except语句:

try:

  检测范围

except Exception_name[as reason(可有可无,用来显示错误原因)]:

  出现异常后的处理代码

 

PS:try语块一旦执行到异常处,程序会跳过后面的语句执行,直接执行except中的语句

raise ExceptionType:用于故意抛出异常

30.else与while的配合:

如果if中的语句全部被执行,没有中途跳出,则else中的语句会被执行;有中途跳出则不会被执行(注意else的缩进是和while同级)

 

 

 

 

 

 

 

 

---恢复内容结束---


推荐阅读
  • 本文档汇总了Python编程的基础与高级面试题目,涵盖语言特性、数据结构、算法以及Web开发等多个方面,旨在帮助开发者全面掌握Python核心知识。 ... [详细]
  • Django Token 认证详解与 HTTP 401、403 状态码的区别
    本文详细介绍了如何在 Django 中配置和使用 Token 认证,并解释了 HTTP 401 和 HTTP 403 状态码的区别。通过具体的代码示例,帮助开发者理解认证机制及权限控制。 ... [详细]
  • 序列化与反序列化是数据处理中的重要技术,特别是在网络通信和数据存储中。它们允许将复杂的数据结构转换为可传输或存储的格式,再从这些格式恢复原始数据。本文探讨了序列化与反序列化的基本概念,以及它们在不同协议模型中的角色。 ... [详细]
  • python时间序列之ADF检验(1)
    读取数据,pd.read_csv默认生成DataFrame对象,需将其转换成Series对象DataFrame和Series是pandas中最常见的2 ... [详细]
  • 本文介绍了一种根据目标检测结果,从原始XML文件中提取并分析特定类别的方法。通过解析XML文件,筛选出特定类别的图像和标注信息,并保存到新的文件夹中,以便进一步分析和处理。 ... [详细]
  • 深入理解Java多线程并发处理:基础与实践
    本文探讨了Java中的多线程并发处理机制,从基本概念到实际应用,帮助读者全面理解并掌握多线程编程技巧。通过实例解析和理论阐述,确保初学者也能轻松入门。 ... [详细]
  • MongoDB的核心特性与架构解析
    本文深入探讨了MongoDB的核心特性,包括其强大的查询语言、灵活的文档模型以及高效的索引机制。此外,还详细介绍了MongoDB的体系结构,解释了其文档、集合和数据库的层次关系,并对比了MongoDB与传统关系型数据库(如MySQL)的逻辑结构。 ... [详细]
  • 本文深入探讨了MySQL中常见的面试问题,包括事务隔离级别、存储引擎选择、索引结构及优化等关键知识点。通过详细解析,帮助读者在面对BAT等大厂面试时更加从容。 ... [详细]
  • 配置PHPStudy环境并使用DVWA进行Web安全测试
    本文详细介绍了如何在PHPStudy环境下配置DVWA( Damn Vulnerable Web Application ),并利用该平台进行SQL注入和XSS攻击的练习。通过此过程,读者可以熟悉常见的Web漏洞及其利用方法。 ... [详细]
  • 搭建Jenkins、Ant与TestNG集成环境
    本文详细介绍了如何在Ubuntu 16.04系统上配置Jenkins、Ant和TestNG的集成开发环境,涵盖从安装到配置的具体步骤,并提供了创建Windows Slave节点及项目构建的指南。 ... [详细]
  • Django 使用slug field时遇到的问题 ... [详细]
  • 本文将详细探讨 Java 中提供的不可变集合(如 `Collections.unmodifiableXXX`)和同步集合(如 `Collections.synchronizedXXX`)的实现原理及使用方法,帮助开发者更好地理解和应用这些工具。 ... [详细]
  • 本文档介绍了如何在Visual Studio 2010环境下,利用C#语言连接SQL Server 2008数据库,并实现基本的数据操作,如增删改查等功能。通过构建一个面向对象的数据库工具类,简化了数据库操作流程。 ... [详细]
  • 本文介绍如何在C#中将GridView控件的内容保存为图片文件。通过代码示例,详细说明了创建位图、绘制图形并保存图像的步骤。 ... [详细]
  • 解决Windows下创建子进程时代码重复执行的问题
    在Windows系统中,当启动子进程时,主进程的文件会被复制到子进程中。由于导入模块时会执行该模块中的代码,因此可能导致某些代码在主进程和子进程中各执行一次。本文探讨了这一现象的原因及其解决方案。 ... [详细]
author-avatar
这个世界我看不懂2011_595
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有