首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

Python学习笔记整理(十三)Pyth

一、模块 模块是Pyhon最高级别的程序组织单元,它将程序代码和数据封装起来以便重用。实际的角度,模块往往对应Python程序文件。 每个文件都是一个模块,并且模块导入其他模块之后就可以使用导入模块定义的变量名。模块可以由两个语句和一个重要的内置函数进行处理。 import: 使客户端(导入者)以一个整体获取一个模块。 from:容许客户端从一个模块文件中获取特定的变量名。 reload:在不中止Python程序的情况下,提供了一个重新载入模块文件代码的方法。 在一个模块文件的顶层定义的所有变量名都成为了被导入的模块对象的属性。 模块至少有三个角色: 代码重用:模块还是定义变量名的空间,被认作是属性。可以被多个外部的客户端应用。 系统命名空间的划分: 现实共享服务和数据: 1、python程序构架 一个ptyhon程序包括了多个含有Python语句的文件。程序是作为一个主体的,顶层的文件来构造的,配合有零个或多个支持文件,在Python中这些文件称作模块。 标准模块:python自带了200多个使用的模块、成为标准连接库 import如何工作 执行三个步骤 1)、找到模块文件 2)、编译成位码(需要时) 3)、执行模块的代码来创建其所定义的对象。 在之后导入相同的模块时候,会跳过这三个步骤,而只提取内存中已加载模块对象。 搜索模块 导入模块时,不带模块的后缀名,比如.py Python搜索模块的路径: 1)、程序的主目录 2)、PTYHONPATH目录(如果已经进行了设置) 3)、标准连接库目录(一般在/usr/local/lib/python2.X/) 4)、任何的.pth文件的内容(如果存在的话).新功能,允许用户把有效果的目录添加到模块搜索路径中去 .pth后缀的文本文件中一行一行的地列出目录。 这四个组建组合起来就变成了sys.path了, >>> import sys >>> sys.path 导入时,Python会自动由左到右搜索这个列表中每个目录。 第1,第3元素是自动定义的,第2,第4可以用于扩展路径,从而包括自己的源码目录。 import b的形式可能加载 源码文件b.py 字节码文件.pyc 目录b 编译扩展模块,比如linux的b.so 用C编写的编译好的内置模块,并通过静态连接至Python ZIP文件组件,导入时自动解压压缩。 java类型,在Jython版本的python中。 .NET组件,在IronPython版本中的Python中 脚本中随处可见 object.attribute这里表达式法:多数对象都有一些可用的属性。可以通过"."运算符取出。 有些是可调用的对象。例如,函数。 第三方工具:distutils 第三方扩展,通常使用标准连接库中的distutils工具来自动安装。使用distutils的系统一般附带setup.py脚本 命令空间是一种独立完备的变量包,而变量就是命名空间对象的属性。模块的命令空间包含了代码在模块文件顶层赋值的所有变量名(也就是没有嵌套与def和class语句中) 二、模块代码编写基础 1、模块的创建和使用。 创建模块 后缀.py文本文件,模块顶层指定的所有变量名都会变成其属性。 定义一个module.py模块 name='diege' age=18 def printer(x):         print x 使用模块 import全部导入 >>> import module 属性 >>> module.name 'diege' 函数 >>> module.printer('hi') hi >>> module.printer('9')  9 from语句 from将获取(复制)模块特定变量名 from 模块名 import 需要复制的属性 from 模块名 import 需要复制的属性 as 新的属性名 from会把变量名赋值到另一个作用域,所以它就可以让我们直接在脚本中使用复制后的变量名,而不是通过模块 >>> from module import name >>> name 'diege >>> from module import name as myname >>> myname 'diege' >>> from module import printer as PR >>> PR('hi python') hi python >>> PR('99')         99 from * 语句 from 模块名 import * 取得模块顶层所有赋了值的变量名的拷贝。 模块只导入一次,因为该操作开销大 import和from是赋值语句,是可执行

05

Python学习笔记整理(四)Pytho

字符串是一个有序的字符集合,用于存储和表现基于文本的信息。 常见的字符串常量和表达式 T1=‘’ 空字符串 T2="diege's" 双引号 T3="""...""" 三重引号块 T4=r'\temp\diege' Raw字符串 抑制(取消)转义,完全打印\tmp\diege,而没有制表符 T5=u’diege' Unicode字符串 T1+T2     合并 T1*3    重复 T2[i]    索引 T2[i:j] 分片 len(T2)  求长 "a %s parrot "% type 字符串格式化 T2.find('ie') 字符串方法调用:搜索 T2.rstrip() 字符串方法调用:移除空格 T2.replace('ie','efk') 字符串方法调用:替换 T2.split(',') 字符串方法调用:分割 T2.isdigit() 字符串方法调用:内容测试 T2.lower() 字符串方法调用:大写转换为小写 for x in T2:  迭代 'ie' in T2 成员关系 一、字符串常量 1、单双引号字符串是一样 Python自动在任意表达式中合并相邻的字符串常量。尽管可以在他们之间增加+操作符来明确表示这是一个合并操作。 >>> T2="Test " 'for ' "diege" >>> T2 'Test for diege' >>> T2="Test "+'for '+"diege"  >>> T2 'Test for diege' 不能在字符串之间增加逗号来连接,这样会创建一个元组而不是字符串。python倾向于打印所有这些形式字符串为单引号,除非字符串内有了单引号。 不过也可以通过反斜杠转义嵌入引号 >>> T2="Test "+'for '+"diege's" >>> T2 "Test for diege's" >>> 'diege\'s' "diege's" 2、用转义序列代表特殊字节 \newline     忽视(连续) \\        反斜杠(保留\) \'        单引号(保留') \"        双引号(保留”) \n         换行 \f        换页 \t         水平制表符 \v         垂直制表符 \b        倒退 前的字符没有了 \a        响铃 \r        返回 前面的字符没有了 \N{id}        Unicode数据库ID \uhhhh        Unicode16位的十六进制值 \Uhhhh        Unicode32位的十六进制值 \xhh        十六进制值 \ooo        八进制值 \0        NULL (不是字符串结尾) \other        不转义(保留) 3、字符串抑制转义 myfile=open('C:\new\text.data','w') 这个调用会尝试打开C:(换行)ew(制表符)ext.data的文件,而不是期待的结果。 解决办法,使用raw字符串。如果字母r(大写或者小写)出现在字符串的第一个引号前面,它会关闭转义机制。 myfile=open(r'C:\new\text.data','w')‘ 另外一个办法就是把\转义 myfile=open('C:\\new\\text.data','w')‘ 4、三重引号编写多行字符串块 块字符串,编写多行文本数据便捷语法。 这个形式以三重引号开始(单双引号都可以),并紧跟任意行的数的代码,并且以开头同样的三重引号结尾。嵌入这个字符串文本中的单引号双引号也会但不是必须转义。三重引号字符串也常用在开发过程中作为一个种***风格的方法去废除一些代码。如果希望让一些代码不工作,之后再次运行代码,可以简单地在这几行前,后加入三重引号 X=10 """ import os print os.getcwd() """ Y=19 5、字符串编码更大的字符集 Unicode字符串有时称为“宽”字符串。因为每个字符串也许在内存会占用大于一个字节的空间。 Unicode字符串典型的应用于支持国际化的应用(i18) 通过在开头的引号前增加字母u(大小写都可以)编写一个Unicode字符串。 >>> T9=u'diege'  #这种语法产生了一个unicode字符串对象。 >>> T9 u'diege' >>> type(T9) <type 'unicode'> Python中允许表达式自由地混合Unicode字符串和一般字符串。并将混合类型的结果转为Unicode。 Unicode字符串也可以合并,索引,分片。通过re模块进行匹配,并且不能够进行实地修改

01
领券