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

    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运算符(innot 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版本。

    作者:Jonins    出处:http://www.cnblogs.com/jonins/
     
    个人原创,若有错误或补充请联系作者。
     
    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
  • 相关阅读:
    nginx配置文件语法高亮显示方法
    GitLab服务器搭建及配置
    Git服务器搭建及配置
    SVN-Server搭建及配置
    python之subprocess
    jenkins配置从节点
    jenkins邮箱配置以及结合ansible进行批量构建
    tomcat+svn+maven+jenkins实现自动构建
    tomcat结合memcached构建session服务器
    基于tomcat集群做session共享
  • 原文地址:https://www.cnblogs.com/jonins/p/9724911.html
Copyright © 2011-2022 走看看