Python漫漫艰辛路之day1

今天做的内容就是从头整理笔记,方便以后调用查看。

变量

a = 1 表示先从内存中申请一块内存空间。把数据1创建出来。这个“1“也可以称为对象。

变量命名注意事项:

变量名只能是字母、数字或下划线的任意组合

变量名的第一个字符不能是数字

关键字不能声明为变量名

变量名一定要有含义。

变量名不要写拼音和中文。

永远都不改变的量称为常量,在python中要大写。对象可以通过一个点去调用方法。

数据类型

所有的数据类型一定会划分成两种:

一种是可变数据类型:列表,字典

另一种是不可变数据类型: 整型,浮点型,元组,字符串

一旦创建就不能被修改,比如a=1表示给内存空间里开辟了一块空间用来存1的值,然后又a=2,并不是把1值覆盖了,而是又重新创建了一个数据对象,之前的数据对象并没有变,这就叫不可变数据类型。

不同的类型占位也不一样。内存的空间都是有限的,比如10/3,它的结果能无限循环小数,我们不可能把这具结果存到内存里去,不然多大的内存都不够用了,所以我们一定要把这个内存最大使用化。比如整型,假如占一个字节,内存就分配给它一个字节,固定好这个关系,用不完没关系,如果超了就使用另外一个类型。

1、整型int

python3.X版本里,数字如果在整型的范围,它会给你一个固定的字节数,如果超过了,它会识别这个数字的大小,自动给你补上字节数

2、浮点型float 、 doble

和整型一样,只是整型表示整数,浮点型表示小数,浮点型还包括科学计数法,

如:1.23e-4

float 和 doble的区别在于它们后面的小数精确度不一样。doble后面的小数精度非常高。

3、布尔值 True  、 False

最大的用处不是用来运算,而是用于条件判断。

True 代表1,  False代表0

4、字符串 string 包含字符串、元组、列表、字典

字符串都是通过引号引起来的。创建字符串都有两种方式:

一种是最直接的通过某种表达式来创建

如: s = “william”、 l = [1,2,3,4]

另一种是通过关键字来创建。

如:s1 = str(william ) 、l =list(1,2,3,4)

(1)字符串

注意事项:一个字符串里如果有多个引号,可以双引号、单引号交替,也可以和反斜杆进行转义。

例:s = “Let’s go”

s = ‘Let\’s go’

若一个字符串中有多个转义符,为了看起来不麻烦,则在字符串前加上r即可全部转义,如:

s = r“\fade\\\sfe\sfsfa”

对字符串进行操作:

一、查操作:

切片操作

s1 = ‘hello world‘

print(s1[1:4])          # 按下标位顺序取第1至第3位的字符,顾首不顾尾 #输出结果:ell

print(s1[1:4:2])       # 按步长取,不加步长默认是1 #输出结果:el

print(s1[-1])            # 取最后一个字符。#输出结果:d

print(s1[:])      # 取出全部字符。#输出结果:hello world

print(s1[:8])            # 取出下标位顺序从0开始取到第7位 #输出结果:hello wo

print(s1[1:-1])   # 取出下标位1至倒数第二位#输出结果:ello worl

print(s1[1:])            # 取出下标位1至最后所有的字符。# 输出结果:ello world

print(s1[-3:-1])        # 取出下标位倒数第3位至倒数第2位。# 输出结果:rl

二、字符串的方法

对象.方法(参数)

1、strip(参数 )

把字符串开头和结尾处的空格、换行符\n去掉。

(1)s = ‘   hello\nworld‘.strip()

   print(s)

# 输出结果:hello

      world

 注意:只去掉开头和结尾的空格和\n,字符串中间的空格和\n不会被去掉。

(2)s1 = ‘**hello\nworld\n***‘.strip("*")

    print(s1)

# 输出结果:hello

       world

注意:strip(“*”)括号中的*,表示去除带*号的符号

(3)字符串后面可以接多个.strip( )

      

2、拼接方法:+和join

(1) +

s = ‘hello‘+‘world‘

print(s)

# 输出结果:

    helloworld

这种方式效率过低,占用内存空间。只有在拼接次数少的情况下用效率高。

(2)”参数”. join([ “字符串”,“字符串”])

print("*".join(["I","am","world!"]))

# 输出结果:

    I*am*world!

[ ]中一定得是字符串对象。

这种方式效率高,只申请一次内存空间就能拼接起来,推荐使用此方法。

3、切片方法split

”字符串”.split(“参数” )

将一个字符串以指定的分割符切片成若干个列表的

(1)s = "hello world".split("  ")

    print(s)

# 输出结果:

      [‘hello‘,‘world‘]

# 以空格为分隔符,将"hello world"分隔成一个列表。

(2)s = "hello world".split("e")

    print(s)

# 输出结果:

   [‘h‘,‘llo  world‘]

# 以字符e为分隔符,将"hello world"分隔成一个列表。

(3)s = ‘hello world ‘.split("l",1)

    print(s)

# 输出结果:

   [‘he‘ , ‘lo  world‘]

# 表示以字符"l"为分隔符,将"hello world"分隔成了一个列表,后面的1表示分隔字符"l"一次

4、查找字符方法find和index

1、find方法

“字符串”.find(“查找的字符”)     最终显示要查的字符的位置

(1) print("hello world".find("e"))

# 输出结果:

  1

# 表示"e"在字符串中第1个位置

(2)print("hello world".find("l"))

# 输出结果:

  2

# 表示"l"在字符串中从左至右数第1个字符"l"所在的位置。

(3)print("hello world".rfind("l"))

# 输出结果:

  9

# 表示在字符串中从右至左数的第一个字符"l"所在的位置。

5、替换方法 replace

“字符串”.replace(“要替换的旧内容”,“新内容”)

(1)print("hello world".replace("world","Python"))

#输出结果:

  hello Python

# 这种方式叫做完全匹配,只要匹配的内容中不一样,就会报错。

replace没有返回值,对字符串这种不可变类型进行操作一定是返回一个新的字符串类型,而之前的s不会发生任何变化。

6、format() 方法,格式化出

通过键值对形式关键字传参,而且可以随意换位置也不影响。(推荐方法)

(1)s = ‘my name is {name}, I am {age} years old‘

    print(s.format(name = "william", age = "29"))

#输出结果:

  my name is william, I am 29 years old

(2) print(‘hello {0}, his age is {1}‘.format("alex",34))

#输出结果:

  hello alex,his age is 34

7、% : 格式化输出

(1)%s:给字符串占位

1) print("hello  %s"%"sb")

#输出结果:

  hello  sb

2)print("hello  %s,%s"%("sb","egon"))

#输出结果:

  hello sb,egon

# 替换多个字符串时,小括号里的字符串一一对应

(2)%d : 给整型占位

print("hello %s,his age is %d"%("sb",35))

#输出结果:

  hello sb, his age is 35

这里的%d换成%s也没有问题,就是把“35”这个数字转换成了字符形式。不是特别需要时,建议用%s,不容易出错,。

(3)%f:给浮点型占位。

print("hello %s,his age is %f"%("sb",35))

#输出结果:

  hello sb,his age is 35.000000

三、列表操作

它很像生活中的清单。清单中每样物品都是一个并列的方式,而且都有一个索引(第几行)

1、列表的创建:

(1)直接通过{ }创建

变量名 = [参数,参数,“参数”,{} ],其中参数可以放整型,可以放字符串,也可以嵌套列表、字典、元组。

例:

l = [“hello”,[4,5],{“name”:”egon”}]

概念:字符串、元组、列表等都叫作可迭代对象。那什么叫作可迭代对象呢?能够进行for循环的都是可迭代对象。

(2)通过list赋予变量名来创建列表:

例:

l2 = list( [1,2,3] )  # 其中[ ]在里面表示是一个序列,并不是列表。

l2 = list((1,2,3))   # 其中()在里面也只是一个序列,并不是元组。

通过list创建列表中,小括号里的 [ ] 和()只是组织元素通过list称为一个整体之后对它进行一个实例化。

2、对列表进行增删改查

实际工作中用得最多的就是对列表进行增删改查,比字符串的操作用得多。

(1)l3 = [1,23,3,43,5345,564,656,77] # 顾首不顾尾。

    print(l3[-2:])

#输出结果:

  [656,77]

(2)列表的增加

.append( ) 添加元素到末尾,且只能添加一个元素。打印时返回空值。

l3 = [1,23,3,43,5345,564,656,77]

l3.append("yuan") # 在列表l3后面的添加“yuan”字符

print(l3)

#输出结果:

[1,23,3,43,5345,564,656,77,"yuan"]

(3).extend( ) 添加多个元素到末尾。

l3 = [1,23,3,43,5345,564,656,77]

l3.extend([7,8])

print(l3)

#输出结果:

[1,23,3,43,5345,564,656,77,[7,8]]

(3).insert( ) 添加元素到指定位置。

l3 = [1,23,3,43,5345,564,656,77]

l3.insert(2,"jjj") # 表示在位置2的位置插入‘jjj‘

print(l3)

#输出结果:

[1,23,‘jjj‘,[‘hello‘,334],656,77]

3、列表的删除:

(1)按位置删除pop

.pop()按索引值删除列表中的元素,括号内不加参数表示默认删除列表中的最后一个。在小括号中加入数字删除表示删除指定索引值的元素。

pop有返回值,返回删掉的那个值的返回值。

(2)按具体内容删除remove

.remove( ) 不知道列表中的元素的位置,但是知道元素的内容。

(3)del删除

不但能能过索引删除列表数据,也可以通内容删除数据,只要能从列表中取出的数据都能删除。还能删除所有的数据。

del不但能删列表中的元素,还能把列表删了。

( 4 ) 列表的改——赋值操作。

通过切片找到要改的数据

4、统计列表中指定元素的个数 .count( ) 括号中输入要统计的元素名称。

四、字典

字典是一种可变的数据类型。字典是无序的。

字典和列表一样,都是用来存储数据的,只是存储的方式不一样。字典是python里唯一具有映射关系的数据类型。字典的查询效率要高于列表,列表的存储方式是线形存储,复杂度是ON,而字典它的复杂度只有1,字典的存储空间要大,因为它要建立一张映射表,硬射表是要占空间的。我们创建一个字典,就有一个键就对应一个值,它要为这些键值创建一个对应表,而这张表在内存里面是要消耗空间的,所以字典相当于空间换取时间,它用内存的占用量去换取查询的速度。

映射的意思就是一 一对应,一对多。

python的字典就像是现实中的字典一样,每一行目录对应一种字的解释。

1、创建字典的两种方法

(1) {}创建字典

(2) 用内置函数dict( )

变量名={“键”,“值”}

写一个键就能通过哈希算法专进行查询到这个键所对应 的值。

注意事项

1)在字典里键值必须要用引号,否则它会认为是一个变量,最终因为没有给这个变量赋值而报错,用数字没有问题。

2)键具有唯一性。在字典里不能定义两个或两个以上相同的键,否则打印里它只会映射最后一个值。

3)键为不可变数据类型。可以用字符串,整型,元组,用其它数据类型会直接报错。

4)键对应的值可以是任何数据类型。

2、字典的查操作。

查询固定的某一个键下的一个值。通过键去查询:

1)    变量名[ ]    进行查

2)  变量名 . get()方法进行查             # 推荐使用

用第二种方法取键的值如果取不到可以在后面加上None,给返回一个空值。

字典for循环时,找键的时候是找i ,找值的时候通过d [ i ]去拿

第二种方法是使用%s(格式化输出)来取键和值,

3、字典的增操作

update:更新覆盖,如果有则覆盖,如果没有则添加。

注意:可变数据类型都没有返回值。

4、字典的修改

d [ 要修改的键值 ] = 修改后的值。

如果键已经存在,那么会覆盖原来的键的值。

5、字典的删除

(1)a.pop(键的名称):a为字典的变量名

(2)del 也能删除字典

(3)clear()清空整个字典内容

a.clear清空后,字典还在,变成了空字典。

(4)popitem() 随机删除

补充:

a:所有对象都能调用方法。

b:None并非空值,它不是数据,它可以进行if判断,它本身就是一个结果。None的作用是以后我们写代码报错经常看到的这个NoneType的结果时,我们就应该对应考虑一下是否哪个值为空,导致某些对象不能调用了而报错。

真正为空值的是:空列表{}、空元组()、空字典{}、0,这些都是一个个的数据,只是它们里面没有具体的值。

时间: 2024-10-06 03:03:09

Python漫漫艰辛路之day1的相关文章

Python学习之路,Day1 – Python基础1

写在前面的话: 大学毕业之后没有从事自己专业方面的工作,期间也做了很多工作,现在来到了一家物流公司,但是每天日复一日的工作,枯燥,乏味,发现这并不是自己想要的,自己也有自己的梦想,也有自己的追求,想起蒂夫·乔布斯说过,每个人都应该学习给电脑编写程序的技术,因为这一过程能够教你如何去思考! 在茫茫的编程语言中我选择了python,因为感觉它强大,应用到众多领域,相对其他语言或与更加的简单,既然选择过后就要走下去,自己选择的路,不留遗憾. Python学习第一天 本节内容: Python介绍 Pyt

我的Python学习之路(day1)

一直以来都不喜欢开发,也比较排斥,于是大学分专业选择了网络工程.但是学院又不重视网络,大四实习的时候都去培训开发唯独我选择了继续沿着网络方向走下去.现在已经工作一年多了,传统网络工程师的需求已经非常小了.最终还是回到了开发,选择了Python,开启我人生的新征程. 这是到今天为止我写过最长的一段代码,会有很多不完善的地方希望各大佬多多指导我这个刚入门的小菜鸟 #Author:Tannar product_list = [     ('Iphone',5800),     ('Mac Pro',1

Python学习之路【第一篇】-Python简介和基础入门

1.Python简介 1.1 Python是什么 相信混迹IT界的很多朋友都知道,Python是近年来最火的一个热点,没有之一.从性质上来讲它和我们熟知的C.java.php等没有什么本质的区别,也是一种开发语言,而且已经进阶到主流的二十多种开发语言的top 5(数据源自最新的TIOBE排行榜). 来头不小啊!二十多种主流的开发语言,我该从哪一个开始呢?人生苦短,let‘s python! 1.2 Python的由来和发展趋势 Python的前世源自鼻祖“龟叔”.1989年,吉多·范罗苏姆(Gu

漫漫自由路--曼德拉自传

一开始接触到曼德拉名字,是从中学历史课本中,第一个黑人总统(当时印象最深的是做了几十年监狱,还能当上总统,很强大).再后来是听说香港beyond乐队特地为曼德拉写了一首歌"光辉岁月". 在深圳海岸城"论斤称"书店中看到曼德拉自传,三指厚度,黑色硬皮封面上简易第印着书名"漫漫自由路 曼德拉自传",以及曼德拉服刑时的ID:46664.以打6折的价格满了一本来阅读. 1. 曼德拉生平简介: 曼德拉不是一个穷人.甚至可以说是一个"王二代&quo

Python学习之路-Day1-Python基础

Python学习之路第一天 学习内容: 1.Python简介 2.安装 3.第一个Python程序 4.变量 5.字符编码 6.用户输入 7.表达式if..else语句 8.表达式for语句 9.break和continue 10.while循环 11.字符串格式化 1.python简介 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解释程序,作为ABC语言的一种继承. 最新的TIOB

Python学习之路

Python学习之路 目录 Python学习之路[第一篇]:流程控制,用户交互,语法要求,变量,字符,注释,模块导入的使用 Python学习之路[第二篇]:文件,字符串,列表,元组,字典,集合的使用 更新中...

Python爬虫之路——简单的网页抓图

转载自我自己的博客:http://www.mylonly.com/archives/1401.html 用Python的urllib2库和HTMLParser库写了一个简单的抓图脚本,主要抓的是http://desk.zol.com.cn/meinv/这个链接下的图片,通过得到图集的起始URL地址,得到第一张图片,然后不断的去获取其下一个图片的URL,继而得到所有首页的图集的图片. 整个源码如下,比较简单,写这个只是简单的练手而已 #coding: utf-8 #################

Python爬虫之路——简单网页抓图升级版(增加多线程支持)

转载自我的博客:http://www.mylonly.com/archives/1418.html 经过两个晚上的奋斗,将上一篇文章介绍的爬虫稍微改进了下(Python爬虫之路--简单网页抓图),主要是将获取图片链接任务和下载图片任务用线程分开来处理了,而且这次的爬虫不仅仅可以爬第一页的图片链接的,整个http://desk.zol.com.cn/meinv/下面的图片都会被爬到,而且提供了多种分辨率图片的文件下载,具体设置方法代码注释里面有介绍. 这次的代码仍然有点不足,Ctrl-C无法终止程

我的Python自学之路一:Python学习路线

作为以为小白,在学习Python的时候,必然会走一定的弯路,有人在弯路上走丢了,有人走出了弯路.我就是属于还未走出弯路的同学,所以我想谈谈我的Python学习之路. 我进入这个坑是因为这个最近几年比较火,想必大家都知道吧,我开始学习Python时,先学习的是linux基本命令,作为小白,在装linux时出现许多问题,小白安装可以看看http://blog.csdn.net/u013142781/article/details/50529030这个教程,可能能帮助你成功安装. 其次,学习linux