黑马程序员技术交流社区

标题: 基础学习 [打印本页]

作者: chen258    时间: 2018-10-7 12:38
标题: 基础学习
   学了也有十几天了,感觉学的不厉害,因为有篇技术贴要求,就写写最基础的:

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]

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

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)
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)
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:分隔符,默认为所有的空字符,包括空格、换行( )、制表符(        )等。

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() 方法按照行(' ', ' ', ')分隔,返回一个包含各行作为元素的列表,如果参数 keepends 为 False,不包含换行符,如果为 True,则保留换行符。

语法格式:

1 myStr.splitlines([keepends])

说明:

myStr:指定分割的字符串。

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

示例如下:

1 myStr = 'hello  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提供的 index 和 count 方法实现检测,具体使用方式与 字符串中使用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)

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

字典常用操作(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())


公共方法

运算符



注意 : in 和 not in 在对字典操作时,判断的是 字典的key(键) 。

内置函数




    哈哈





欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2