Python基础(中)

前言

print("                            _ooOoo_                     ")
print("                           o8888888o                    ")
print("                           88  .  88                    ")
print("                           (| -_- |)                    ")
print("                            O\\ = /O                    ")
print("                        ____/`---‘\\____                ")
print("                      .   ‘ \\| |// `.                  ")
print("                       / \\||| : |||// \\               ")
print("                     / _||||| -:- |||||- \\             ")
print("                       | | \\\\\\ - /// | |             ")
print("                     | \\_| ‘‘\\---/‘‘ | |              ")
print("                      \\ .-\\__ `-` ___/-. /            ")
print("                   ___`. .‘ /--.--\\ `. . __            ")
print("                ."" ‘< `.___\\_<|>_/___.‘ >‘"".         ")
print("               | | : `- \\`.;`\\ _ /`;.`/ - ` : | |     ")
print("                 \\ \\ `-. \\_ __\\ /__ _/ .-` / /      ")
print("         ======`-.____`-.___\\_____/___.-`____.-‘====== ")
print("                            `=---=‘  "                   )
print("                                                        ")
print("         .............................................  ")
print("                  佛祖镇楼             国庆快乐            ")

字符串基础(String)

python中字符的定义使用单引号或者双引号都可以,例如:

str1="Hello"
#或者
str2="Jonins"

注意:在python3中input获取键盘输入的数据,都以字符串的方式进行保存,即使输入的是数字。

下标&切片

1.下标

下标:可以理解为数组类数据类型内元素的索引。列表与元组支持下标索引,字符串是字符的数组,所以也支持下标索引。索引从0开始,而内存中实际存储如下:

2.切片

切片:是指对操作的对象截取其中一部分的操作。字符串、列表、元组都支持切片操作。切片的语法格式如下:

1 变量名[起始:结束:步长]

注意:选取的区间属于左闭右开型,既从起始位开始,到结束位的前一位,不包含结束位本身。说明示例如下:

1 name=‘0123456789‘
2 print(name[0:3])#取下标0-2的字符
3 print(name[3:5])#取下标3-4的字符
4 print(name[3:])#取下标3开始到最后的字符
5 print(name[3:-3])#取下标3开始到倒数第3个之间的字符(不包含倒数第三)
6 print(name[3:-1:2])#取标3开始到倒数第一个之间间隔为2-1的字符(步长,默认是1,当指定的时取值是步长的值,可以理解为中间间隔(步长-1))
7 print(name[-1::-1])#倒叙输出字符串

列表基础(List)

1.列表基础

列表类型的格式:

1 testList=[xxx,yyy,zzz....nnn]

列表支持切片和下标操作,而pythonC语言的数组强大的地方在于列表中的元素可以是不同类型的:

1 tuple=[‘jonins01‘,2,‘jonins02‘,3.3]
2 print(tuple[2])
3 tuple2=tuple[0:2]
4 print(tuple2)

2.列表的遍历

为了更有效的输出列表的每个数据,可以使用循环来完成,列表的遍历可以使用for循环或者while循环来实现,示例如下:

1 nameList=[‘jonins1‘,‘jonins2‘,‘jonins‘]
2 print(‘-----for循环遍历-----‘)
3 for name in nameList:
4     print(name)
5 print(‘-----while循环遍历-----‘)
6 i=0
7 while i<len(nameList):
8     print(nameList[i])
9     i+=1

元组基础(Tuple)

1.元组基础

python的元组与列表类似,不同之处在于元组的元素不能修改元组使用小括号,列表使用方括号。列表的格式如下:

1 tuple=(xxx,yyy,zzz....nnn)

python中不允许修改元组的数据,包括不能删除其中的元素元组同样支持切片和下标操作

1 tuple=(‘jonins1‘,2,‘jonins‘,3.3)
2 print(tuple[2])
3 tuple2=tuple[0:]
4 print(tuple2)

2.元组的遍历

元组同样可以遍历,通过for循环和while循环都可以实现:

1 tuple=(‘jonins1‘,2,‘jonins‘,3.3)
2 print(‘-----for循环遍历-----‘)
3 for t in tuple:
4     print(t)
5 print(‘-----while循环遍历-----‘)
6 i=0
7 while i<len(tuple):
8     print(tuple[i])
9     i+=1

字典基础(Dictionary)

1.字典基础

说明:字典是key/value键值对集合。字典和列表一样,都可以存储多个数据。列表中找某个元素是根据下标进行,而字典中找某个元素是根据key查找。字典的格式如下:

1 info={‘key1‘:value1,‘key2‘:value2,......‘keyn‘:valuen}

示例:

1 info={‘name‘:‘jonins‘,‘age‘:18,‘sex‘:‘man‘}
2 print(info[‘age‘])

注意:

1.字典的键(key)可以是任何不可变类型。但不可重复。

2.字典的值(value)可以是任何类型。

3.若访问不存在的键(key)则会报错。

2.字典的遍历

字典提供内置的方法keys()values()items()方法,可以根据需求做所需要的遍历操作,示例如下:

 1 info={‘name‘:‘jonins‘,3:18,‘sex‘:‘man‘}
 2 print(‘遍历字典的键(key)‘)
 3 for key in info.keys():
 4     print(key)
 5 print(‘遍历字典的值(value)‘)
 6 for value in info.values():
 7     print(value)
 8 print(‘遍历字典的项(元素)‘)
 9 for item in info.items():
10     print(item)

字符串常用操作(String)

1.find&rfind

find() 方法检测字符串中是否包含子字符串 str ,如果指定 start(开始) 和 end(结束) 范围,则检查是否包含在指定范围内,如果指定范围内如果包含指定索引值,返回的是索引值在字符串中的起始位置。如果不包含索引值,返回-1。

rfind()方法类似于find()方法,不过是从右边开始查找。

语法格式:

1 myStr.find(str,start,end)

说明:

myStr:指定检索的字符串。

str:检测的字符串或字符。

start:开始索引,默认为0。

end: 结束索引,默认为字符串的长度。

示例如下:

1 stringInfo = ‘hello my name is jonins‘
2 result = stringInfo.find(‘my‘, 0, len(stringInfo))
3 print(result)

2.index&rindex

find()方法一样,index()如果在检测字符或字符串不存在会报一个异常。

rindex()方法类似于index(),不过是从右边开始。

3.count

count() 方法用于统计字符串里某个字符出现的次数。可选参数为在字符串搜索的开始与结束位置。

语法格式:

1 myStr.count(str,start,end)

说明:

myStr:指定检索的字符串。

str:搜索的子字符串

start:字符串开始搜索的位置。默认为第一个字符,第一个字符索引值为0。

end:字符串中结束搜索的位置。字符中第一个字符的索引为 0。默认为字符串的最后一个位置。

示例如下:

1 stringInfo = ‘hello my name is jonins‘
2 result = stringInfo.count(‘m‘, 0, -1)
3 print(result)

4.replace

eplace() 方法把字符串中的 old(旧字符串) 替换成 new(新字符串),如果指定第三个参数max,则替换不超过 max 次。

语法格式:

1 myStr.replace(old, new[, max])

说明:

myStr:指定替换的字符串。

old:将被替换的子字符串。

new:新字符串,用于替换old子字符串。

max :可选字符串, 替换不超过 max 次

示例如下:

1 stringInfo = ‘jonins jonins jonins jonins ‘
2 stringInfo=stringInfo.replace(‘jonins‘,‘jon&ins‘, 2)
3 print(stringInfo)

5.split

split()通过指定分隔符对字符串进行切片,如果参数num 有指定值,则仅分隔 num 个子字符串。返回分割后的字符串列表。

语法格式:

1 myStr.split(str, num)

说明:

myStr:指定分割的字符串。

str:分隔符,默认为所有的空字符,包括空格、换行(\n)、制表符(\t)等。

num:分割次数。

示例如下:

1 stringInfo = ‘jonins jonins jonins jonins ‘
2 stringInfoList=stringInfo.split(‘ ‘, 2)
3 print(stringInfoList)

6.capitalize

capitalize()方法将字符串的第一个字母变成大写,其他字母变小写。示例如下:

1 stringInfo = ‘jonins jonins jonins jonins ‘
2 stringInfo=stringInfo.capitalize()
3 print(stringInfo)

7.title

title()方法返回"标题化"的字符串,所有单词的首个字母转化为大写,其余字母均为小写。示例如下:

1 stringInfo = ‘jonins jonins jonins jonins ‘
2 stringInfo=stringInfo.title()
3 print(stringInfo)

8.startswith&endswith

startswith()方法用于检查字符串是否是以指定子字符串开头,如果是则返回 True,否则返回 False。如果参数 start 和 end 指定值,则在指定范围内检查。

endswith() 方法用于判断字符串是否以指定后缀结尾,如果以指定后缀结尾返回True,否则返回False。如果参数 start 和 end 指定值,则在指定范围内检查。

语法格式:

1 myStr.startswith(str, start,end)#检测指定开始
2 myStr.endswith(str, start,end)#检测指定结尾

说明:

myStr:指定检索的字符串。

str:该参数可以是一个字符串或者是一个元素。

start:字符串中的开始位置。

end:字符中结束位置。

示例如下:

1 stringInfo = ‘hello jonins‘
2 startFlag=stringInfo.startswith(‘hel‘)
3 endFlag=stringInfo.endswith(‘ins‘)
4 print(startFlag)
5 print(endFlag)

9.lower&upper

lower()方法转换字符串中所有大写字符为小写。

upper()方法将字符串中的小写字母转为大写字母。

示例如下:

1 stringInfo = ‘heLlO jOnInS‘
2 lowerStr=stringInfo.lower()
3 upperStr=stringInfo.upper()
4 print(lowerStr)
5 print(upperStr)

10.ljust&rjust&center

ljust()方法返回一个原字符串左对齐,并使用空格填充至指定长度的新字符串。如果指定的长度小于原字符串的长度则返回原字符串。

rjust()方法返回一个原字符串右对齐,并使用空格填充至长度 width 的新字符串。如果指定的长度小于字符串的长度则返回原字符串。

center()方法返回一个指定的宽度 width 居中的字符串,fillchar 为填充的字符,默认为空格。

语法格式:

1 myStr.ljust(width,fillchar)
2 myStr.rjust(width,fillchar)
3 myStr.center(width,fillchar)

说明:

myStr:指定需对齐的字符串。

width:指定字符串长度。

fillchar:填充字符,默认为空格。

示例如下:

1 stringInfo = ‘jonins‘
2 ljustStr=stringInfo.ljust(10)#左对齐
3 rjustStr=stringInfo.rjust(10)#右对齐
4 centerStr=stringInfo.center(10)#居中
5 print(‘-%s-‘%ljustStr)
6 print(‘-%s-‘%rjustStr)
7 print(‘-%s-‘%centerStr)

11.lstrip&rstrip&strip

lstrip()方法用于截掉字符串左边的空格或指定字符(默认为空格)。

rstrip()方法用于删除字符串末尾的指定字符(默认为空格)。

strip()方法用于移除字符串头尾指定的字符(默认为空格)或字符序列。该方法只能删除开头或是结尾的字符,不能删除中间部分的字符。

语法格式:

1 myStr.lstrip(chars)#删除左边的某字符
2 myStr.rstrip(chars)#删除右边的某字符
3 myStr.strip(chars)#删除两端的某字符

说明:

myStr:指定检索的字符串。

chars:指定移除的字符。

示例如下:

1 myStr = ‘  jonins  ‘
2 lstripStr=myStr.lstrip()
3 rstripStr=myStr.rstrip()
4 stripStr=myStr.strip()
5 print(‘-%s-‘%lstripStr)
6 print(‘-%s-‘%rstripStr)
7 print(‘-%s-‘%stripStr)

12.partition&rpartition

partition()方法用来根据指定的分隔符将字符串进行分割。如果字符串包含指定的分隔符,则返回一个3元的元组,第一个为分隔符左边的子串,第二个为分隔符本身,第三个为分隔符右边的子串。

rpartition()方法类似于partition(),不过是从右开始。示例如下:

1 myStr = ‘my name is jonins‘
2 strTuple=myStr.partition(‘name‘)
3 print(strTuple)

13.splitlines

splitlines()方法按照行(‘\r‘, ‘\r\n‘, \n‘)分隔,返回一个包含各行作为元素的列表,如果参数 keepends 为 False,不包含换行符,如果为 True,则保留换行符。

语法格式:

1 myStr.splitlines([keepends])

说明:

myStr:指定分割的字符串。

keepends :默认为 False,不包含换行符,如果为 True,则保留换行符。

示例如下:

1 myStr = ‘hello \n jonins‘
2 strList=myStr.splitlines()
3 print(strList)

14.isalpha&isdigit&isalnum&isspace

isalpha()方法检测字符串是否只由字母组成。

isdigit()方法检测字符串是否只由数字组成。

isalnum()方法检测字符串是否由字母和数字组成。

isspace()方法检测字符串是否只由空白字符组成

示例如下:

1 isalphaStr=‘abcd‘.isalpha()#判断是否只有字母
2 isdigitStr=‘1234‘.isdigit()#判断是否只有数字
3 isalnumStr=‘a1b2c3‘.isalnum()#判断是否只有字母和字母
4 isspaceStr=‘  ‘.isspace()#判断是否只有空白字符
5 print(isalphaStr)
6 print(isdigitStr)
7 print(isalnumStr)
8 print(isspaceStr)

15.join

join()方法用于将序列中的元素以指定的字符连接生成一个新的字符串。

语法格式:

1 str.join(sequence)

说明:

str:指定连接的字符。

sequence:要连接的元素序列。

示例如下:

1 strList=[‘my‘,‘name‘,‘is‘,‘jonins‘]
2 str=‘ ‘
3 stringInfo=str.join(strList)
4 print(stringInfo)

列表常用操作(List)

1.添加元素(append&extend&insert)

append()方法用于在列表末尾添加新的对象。

extend()函数用于在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表)。

insert()函数用于将指定对象插入列表的指定位置。

示例如下:

1 A=[‘1‘,‘2‘,‘3‘,‘4‘]
2 A.append(‘5‘)#尾部追加一个元素
3 print(A)
4 B=[‘101‘,‘102‘,‘103‘]
5 B.extend(A)#尾部追加一个集合
6 print(B)
7 B.insert(2,‘INSERT‘)#在下标2处追加元素
8 print(B)

2.修改元素

修改元素的时候,要通过下标来确认要修改那个元素,然后才能进行修改,示例如下:

1 A=[‘1‘,‘2‘,‘3‘,‘4‘]
2 A[0]=‘01‘
3 print(A)

3.查找元素(in&not in&index&count)

可以使用python运算符(in、not in)来判断列表是否存在指定的元素,示例及说明如下:

in(包含):如果存在那么结果为Ture,否则为False。

not in(不包含):如果不存在那么结果为Ture,否则为False。

1 A=[‘1‘,‘2‘,‘3‘,‘4‘]
2 flag1=‘2‘ in A
3 flag2=‘2‘ not in A
4 print(flag1)
5 print(flag2)

也可以使用python提供的indexcount方法实现检测,具体使用方式与字符串中使用index和count方法的用法相同,示例及说明如下:

index()方法用于从列表中找出某个值第一个匹配项的索引位置。

count()方法用于统计某个元素在列表中出现的次数。

1 A=[‘1‘,‘2‘,‘3‘,‘4‘]
2 flag1=A.index(‘3‘)
3 flag2=A.count(‘3‘)
4 print(flag1)
5 print(flag2)

4.删除元素(del&pop&remove)

del:根据下标进行删除。

pop:删除最后一个元素。

remove:根据元素的值进行删除。

示例如下:

1 A=[‘1‘,‘2‘,‘3‘,‘4‘,‘5‘]
2 del A[0]#根据下标删除元素
3 A.pop()#删除最后一个元素
4 A.remove(‘3‘)#根据元素值删除元素
5 print(A)

5.排序(sort&reverse)

sort() 方法用于对原列表进行排序,如果指定参数,则使用比较函数指定的比较函数。而reverse()方法用于反向列表中元素(逆置)。

语法格式:

1 list.sort(cmp=None, key=None, reverse=False)

说明:

cmp:可选参数, 如果指定了该参数会使用该参数的方法进行排序。

key:主要是用来进行比较的元素,只有一个参数,具体的函数的参数就是取自于可迭代对象中,指定可迭代对象中的一个元素来进行排序。

reverse:排序规则,reverse = True 降序, reverse = False 升序(默认)。

示例如下:

1 A=[‘1‘,‘2‘,‘5‘,‘4‘,‘3‘]
2 A.reverse()#列表逆置
3 print(A)
4 A.sort()#列表升序排序
5 print(A)
6 A.sort(reverse=True)#列表降序排序
7 print(A)

元组常用操作(Tuple)

元组内置的函数indexcount,它们的用法与字符串和列表中的用法相同

字典常用操作(Dictionary)

1.修改元素

字典中的每个元素只要通过key(键)找到,即可修改。示例:

1 info={‘name‘:‘jonins‘,‘age‘:‘18‘}
2 info[‘age‘]=‘20‘
3 print(info)

2.添加元素

当指定key(键)来访问元素时若该键不存,则会报错。如果要添加元素,可以使用:

1 变量名[‘键‘]=数据

的方式,当键不存在时,就会新增这个元素。示例如下:

1 info={‘name‘:‘jonins‘,‘age‘:‘18‘}
2 info[‘id‘]=‘1001‘
3 print(info)

3.删除元素(del&clear)

del可以删除指定的元素,也可删除整个字典,删除整个字典后不允许访问字典,否则会报错。

clear()方法可以清空整个字典,允许清口后访问字典。

示例如下:

1 infoA={‘name‘:‘jonins‘,‘age‘:‘18‘,‘id‘:‘1001‘,‘sex‘:‘man‘}
2 infoB={‘name‘:‘jonins‘,‘age‘:‘18‘,‘id‘:‘1001‘,‘sex‘:‘man‘}
3 del infoA[‘id‘]
4 print(infoA)
5 del infoA#删除后,不能访问,否则会报错
6 infoB.clear();
7 print(infoB)

4.判断键(in&not in)

可以使用python运算符(in、not in)判断key(键)是否存在,示例及说明如下:

in(包含):如果存在那么结果为Ture,否则为False。

not in(不包含):如果不存在那么结果为Ture,否则为False。

1 info={‘name‘:‘jonins‘,‘age‘:‘18‘,‘id‘:‘1001‘,‘sex‘:‘man‘}
2 print(‘name‘ in info)
3 print(‘name‘ not in info)

5.其它内置及常用函数

len()方法用于测量字典中的键值对个数。

keys()方法返回一个包含字典所有key(键)的列表。

values()方法返回一个包含字典所有value(值)的列表。

items()方法返回一个包含所有(key,value)元组的列表。

示例如下:

1 info={‘name‘:‘jonins‘,‘age‘:‘18‘,‘id‘:‘1001‘,‘sex‘:‘man‘}
2 print(len(info))
3 print(info.keys())
4 print(info.values())
5 print(info.items())

公共方法

运算符

注意innot in在对字典操作时,判断的是字典的key(键)

内置函数

结语

若无特殊说明,文章内的示例和说明,默认适用于Python3并不一定兼容于Python2。

作者Python解释器为Python3.6版本。

原文地址:https://www.cnblogs.com/jonins/p/9724911.html

时间: 2024-10-28 19:43:40

Python基础(中)的相关文章

Python基础中所出现的异常报错总结

今天我们来探索python中大部分的异常报错 首先异常是什么,异常白话解释就是不正常,程序里面一般是指程序员输入的格式不规范,或者需求的参数类型不对应,不全等等. 打个比方很多公司年终送苹果笔记本,你程序话思维以为是(MAC)电脑笔记本,结果给你个苹果+笔记本...首先类型不对,数量也不对. 先来看几个常见的报错如下: NameError 命名错误 原因是: name 'a' is not defined  命名a还未定义 简单来说就是程序不知道a带表谁 如果a=1 那程序就懂了 a代表1 所以

Python - 基础中的基础

前景 Python可以应用于众多领域,如:数据分析.组件集成.网络服务.图像处理.数值计算和科学计算等众多领域.目前业内几乎所有大中型互联网企业都在使用Python,如:Youtube.Dropbox.BT.Quora(中国知乎).豆瓣.知乎.Google.Yahoo!.Facebook.NASA.百度.腾讯.汽车之家.美团等. 互联网公司广泛使用Python来做的事一般有:自动化运维.自动化测试.大数据分析.爬虫.Web 等. Python与其他语言 C和Python.java.C# C:代码

Python基础中不常用的一些细节

多行注释''' ''',还可以用来多行打印(打印结果也为多行): Python 2.x 的 raw_input 等价于 Python 3.x 的 input: 密码输入: import getpass password = getpass.getpass(u'请输入密码') while...else...和for in...else 中的else语句都是正常循环结束后执行,非break时的跳出. range()函数第三个参数表示步长: >>> for i in xrange(0, 10,

Python基础中的集合,函数——06

集合 python中的集合 由不同的元素组成(去重,没有重复的元素) s = set('hello') print(s) #结果是: s = {'h', 'o', 'e', 'l'} 集合中的元素是无序排列的 每个元素必须是不可变类型(如:数字.字符串.元组) 增加集合元素 s.add(3) 清空集合 s.clear() 删除集合元素 s.pop()#随机删除 s.remove(3)#指定删除,不存在该元素时删除会报错 s.discard(3)#指定删除,不存在该元素时不会报错 集合的关系运算

Python编程中常用的12种基础知识总结

原地址:http://blog.jobbole.com/48541/ Python编程中常用的12种基础知识总结:正则表达式替换,遍历目录方法,列表按列排序.去重,字典排序,字典.列表.字符串互转,时间对象操作,命令行参数解析(getopt),print 格式化输出,进制转换,Python调用系统命令或者脚本,Python 读写文件. 1.正则表达式替换目标: 将字符串line中的 overview.gif 替换成其他字符串 1 2 3 4 5 6 7 8 9 10 11 >>> lin

Python 编程中常用的 12 种基础知识总结

Python 编程中常用的 12 种基础知识总结:正则表达式替换,遍历目录方法,列表按列排序.去重,字典排序,字典.列表.字符串互转,时间对象操作,命令行参数解析(getopt),print 格式化输出,进制转换,Python调用系统命令或者脚本,Python 读写文件. 1.正则表达式替换 目标:将字符串line中的 overview.gif 替换成其他字符串 >>> line = '<IMG ALIGN="middle" SRC=\'#\'" /s

python基础之python中if __name__ == &#39;__main__&#39;: 的解析

当你打开一个.py文件时,经常会在代码的最下面看到if __name__ == '__main__':,现在就来介 绍一下它的作用. 模块是对象,并且所有的模块都有一个内置属性 __name__.一个模块的 __name__ 的值取决于您如何应用模块.如果 import 一个模块,那么模块__name__ 的值通常为模块文件名,不带路径或者文件扩展名.但是您也可以像一个标准的程序样直接运行模块,在这 种情况下, __name__ 的值将是一个特别缺省"__main__". //////

《Python基础教程》(第2版修订版)中要注意的地方

想必现在大家学习Python都会用3.0及以上的版本了,虽然2.X的版本依然很多,但是这两年随着部分开源项目不再支持2.X版本,3.X已经成为趋势. 正是在这样的大背景下,我最近用这本<Python基础教程>做教材的时候,发现作者虽然提及了2.X与3.X的版本有区别,但是有些地方没有点明,甚至会让用3.X版本的朋友引起误导,下面我就随着使用过程,更新一下遇到的一些问题,希望让初学者们不要感到困扰. 首先说一下教材的信息,因为版本很重要 <Python基础教程(第2版 修订版)> 

Python基础要点:字符串和正则表达式中的反斜杠(‘\‘)问题详解

给大家整理的是关于Python字符串和正则表达式中的反斜杠('\')问题以及相关知识点,有需要的朋友们可以学习下. 在Python普通字符串中 在Python中,我们用'\'来转义某些普通字符,使其成为特殊字符,比如 1 In [1]: print('abc\ndef') # '\n'具有换行的作用 2 abc 3 defg 4 5 In [2]: print('abc\tdef') # '\t'具有制位符的作用 6 abc defg 我们还可以用'\'来转义特殊字符,使其成为普通字符,比如 1

Python基础学习-Python中最常见括号()、[]、{}的区别

Python中最常见括号的区别: 在Python语言中最常见的括号有三种,分别是:小括号().中括号[].花括号{}:其作用也不相同,分别用来代表不同的Python基本内置数据类型. Python中的小括号(): 代表tuple元祖数据类型,元祖是一种不可变序列.创建方法很简单,大多数时候都是小括号括起来的. 1 >>> tup = (1,2,3) 2 >>> tup 3 (1, 2, 3) 4 >>> () #空元祖 5 () 6 >>&