Python day two

一、.pyc是什么

该文件就是Python解释器编译之后产生的字节码,只有python可以读。

手动执行不生成.pyc

执行代码有导入别的.py文件,执行后会生成.py同名的.pyc文件:

在python2.0中:

执行.py文件后,会生成一个.pyc和一个__pycache__文件夹。

在python3.0中:

执行.py文件后,生成的.pyc文件放在了__pycache__文件夹下边,

二、常用数据类型

1.数字

int(整型)

在32位机器上,整数的位数为32位,取值范围为-2**31~2**31-1,即-2147483648~2147483647

  在64位系统上,整数的位数为64位,取值范围为-2**63~2**63-1,即-9223372036854775808~9223372036854775807

long(长整型)(python3.0没有了)

跟C语言不同,Python的长整数没有指定位宽,即:Python没有限制长整数数值的大小,但实际上由于机器内存有限,我们使用的长整数数值不可能无限大。

  注意,自从Python2.2起,如果整数发生溢出,Python会自动将整数数据转换为长整数,所以如今在长整数数据后面不加字母L也不会导致严重后果了。

float(浮点型)

浮点数用来处理实数,即带有小数的数字。类似于C语言中的double类型,占8个字节(64位),其中52位表示底,11位表示指数,剩下的一位表示符号。

complex(复数)

复数由实数部分和虚数部分组成,一般形式为x+yj,其中的x是复数的实数部分,y是复数的虚数部分,这里的x和y都是实数。

注:Python中存在小数字池:-5 ~ 257

2.布尔值

真或假;1或0

判断是否是真:当真的时候返回时True,当假的时候返回是False

3.字符串

"hello world"

三、字符串格式化输出

常见几种写法:


name = ‘abc‘

print ("I am %s" %name)

#输出:I am abc

#注意:%s代表字符串;%d代表整数;%f代表浮点数


name = ‘abc‘

print ("I am" + name +"and your ?")

#输出:I am abc and your?

#注意:%s代表字符串;%d代表整数;%f代表浮点数


name = ‘abc‘

age = 22

job = IT

msg = ‘‘‘

imformation is

-----------

Name:%s

Age:%d

Job:%s

-----end---

‘‘‘ %(name,age,job)

print (msg)

#输出:

imformation is

-----------

Name:abc

Age:22

Job:IT

-----end---

#注意:%s代表字符串;%d代表整数;%f代表浮点数

四、列表的语法和使用(其他语言中叫做数组)

创建列表:


name = [‘a‘,‘b‘,‘c‘,‘d‘]

name = list([‘a‘,‘b‘])

1.列表name_list中的a和b都叫做元素;

2.a和b在列表中都有一个下标,下标默认从0开始;

3.列表的切片:


1.管头不管尾:

print(name[0:2])

输出:[‘a‘, ‘b‘]

2.取最后一个值:name[-1]

3.取最后五位:name[-2:]

4.取前边五位:name[:2]

5.如果切片后还要再切片,在后边加[];

取name的前三位,再取后两位,输出:[‘b‘, ‘c‘]

name[:3][-2:]

4.修改列表:

name[1] = "abc"   #中括号里边直接写列表的下标,等号后边是修改后的值;

5.插入字符串:

name.insert(1,‘bb‘) #1为插入的列表下标位置,bb为插入的内容,一次只能插入一个;

6.追加:

name.append(‘cc‘)   #

7.删除:

name.remove(‘cc‘)    #一次只能删除一个

8.del删除列表内容:

del name[0:2]        #删除列表的前两个元素

9.del删除列表:

del name

10.每隔开两个元素打印一个(默认)

写法一:print(name[0::2])    #其中的2代表步长,默认步长为1;

写法二:print(name[0:-1:2])  #这样是不会打印最后一个

11.判断a在不在列表中

print(‘a‘ in name)

12.统计列表中有几个a

print(name.count(‘a‘))

13.把列表中的a改成aaa

aa = name.index(‘a‘)    #先查找a的位置,赋值给变量aa

name[aa]= ‘aaa‘         #修改a为aaa

print(name)             #打印name列表

14.清空列表

print(name.clear())

15.把下列表合到大列表中

name1.extend(name2)

16.反转列表

name.reverse()

17.列表排序

name.sort()

18.列表的浅复制(也称列表的软链接,第一层的列表完全复制,其他层次的列表不copy)

name1 = name.copy()            #复制name列表到name1,

19.列表的深复制(完整复制所有层次的列表内容)

import copy                    #导入name模块

name2 = copy.deepcopy(name)    #完全复制name列表到name2

print name

20.查看列表元素索引

name.index(‘a‘)                #查找a在列表中的位置,也就是下标

五、字符串常用操作

1.移除空格:

a.strip()

2.分割:

a.split()

3.索引:

索引一:

a.index()

索引二:

msg = "hello,{name},{age}"

msg2 = msg.format(name="yang",age=21)

print(msg2)

输出:

hello,yang,21

索引三:

msg = "hello,{0},{1}"

print(msg.format(‘yang‘,20))

输出:

hello,yang,20

4.长度:

print(len(msg2))

5.切片:

name = "abcde"

print(name[0:3])    #输出前三个字符串

输出:

abc

6.输出居中对齐:

print(name.center(20,‘-‘))

-------abcde--------

7.判断字符串有无空格

print (‘‘ in name)

8.首字母大写

print (name.capitalize())

9.判断字符串是否包含特殊字符。可以包含数字和字母,返回True,如果有其他的返回False;

print (name.isalnum())

10.判断是否以a结尾的,是返回True,否则返回False

name.endswith(‘a‘)

11.判断是否以a开始的,是返回True,否则返回False

name.startswith(‘a‘)

12.把字符串全部转成大写

name.upper()

13.把字符串全部转成小写

name.lower()

六、数据运算

1.数据运算符

2.比较运算符

3.赋值运算符

4.逻辑运算符

5.成员运算

6.身份运算

7.二进制运算

七、死循环(while loop)


#当代码循环100次退出,并打印退出。

count = 0                      #设定标志位,次数为0

while True:                    #设定永远为真

print("输出",count)        #如果为真,输出次数是多少

count +=1                  #每循环一次,次数加1

if count == 100:           #如果次数=100,执行以下语句

print("退出")          #打印退出

break                  #退出整个循环

八、字典

1.创建字典(字典可以嵌套字典、列表、元祖、等)

name= {1:‘a‘,2:‘b‘,3:‘c‘}

字典用{}表示;每个值都有一个key对应一个value;

每对值用,隔开;key值是唯一的;没有下标,没有顺序;

2.字典的功能

.clear     清空

.POP       删除

.copy      复制

.get       获取

.item      把字典变成一个元祖,数据太多情况下不要操作此功能。

.values    打印所有的values

.keys      打印所有的key

时间: 2024-10-30 11:58:36

Python day two的相关文章

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