python基础语法 - 数据类型

Python的数据类型:

  • Numbers(数字)
  • String(字符串)
  • List(列表)
  • Tuple(元组)
  • Dictionary(字典)
  • Set(集合)

Numbers(数字)

数字类型分为:整数,浮点数,复数

运算:

+ - * / 加减乘除

** 平方

String(字符串)

  字符串就是一系列字符,在Python中,用引号括起来的都是字符串,其中的引号可以使单引号,也可以是双引号。

 1. 创建字符串

"This is a string."
'This is also a string.'

2.基本操作方法

#重复输出字符串
print('hello'*2)

#切片,通过索引获取字符串中字符
print('helloworld'[2:])

#成员运算符,返回True或False
print('el' in 'hello')

#格式字符串
name = 'Hans'
print('Hi,%s'%a)

#字符串拼接,+号可以直接拼接(低效)
a='123'
b='abc'
string=''.join([a,b])
print(string)

# 删除空白:
string.rstrip()       #删除字符串末尾的空格
string.lstrip()       #删除字符串开头的空格
string.strip()        #删除字符串两端的空格

3.大小写操作

# 字符串大小写相关操作
string.capitalize()         #把字符串的第一个字符大写
string.title()              #所有单词首字母转换为大写
string.swapcase()           #转换 string 中的大小写
string.lower()              #转换 string 中的大写字符为小写
string.upper()              #转换 string 中的小写字符为大写

4.字符串判断

string.isdigit()                                  #检测字符串是否只由数字组成
string.isalpha()                                  #检测字符串是否只由字母组成
string.isspace()                                  #检测字符串是否只由空格组成
string.isalnum()                                  #检测字符串是否由字母和数字组成
string.islower()                                  #检测字符串是否由小写字母组成
string.isupper()                                  #检测字符串是否由大写字母组成
string.isnumeric()                                #检测字符串是否只由数字组成,针对unicode对象
string.isdecimal()                                #检查字符串是否只包含十进制字符,针对unicode对象
string.istitle()                                  #检测字符串中所有的单词拼写首字母是否为大写
string.endswith(obj, beg=0, end=len(string))      #判断字符串是否以指定后缀结尾
string.startswith(obj, beg=0,end=len(string))     #检查字符串是否是以指定子字符串开头
# string.center(width)                                 返回一个原字符串居中,并使用空格填充至长度 width 的新字符串
# string.count(str, beg=0, end=len(string))            返回 str 在 string 里面出现的次数,如果 beg 或者 end 指定则返回指定范围内 str 出现的次数
# string.decode(encoding='UTF-8', errors='strict')     以 encoding 指定的编码格式解码 string,如果出错默认报一个 ValueError 的 异 常 , 除 非 errors 指 定 的 是 'ignore' 或 者'replace'
# string.encode(encoding='UTF-8', errors='strict')     以 encoding 指定的编码格式编码 string,如果出错默认报一个ValueError 的异常,除非 errors 指定的是'ignore'或者'replace'
# string.expandtabs(tabsize=8)                         把字符串 string 中的 tab 符号转为空格,tab 符号默认的空格数是 8。
# string.find(str, beg=0, end=len(string))             检测 str 是否包含在 string 中,如果 beg 和 end 指定范围,则检查是否包含在指定范围内,如果是返回开始的索引值,否则返回-1
# string.index(str, beg=0, end=len(string))            跟find()方法一样,只不过如果str不在 string中会报一个异常.
# string.join(seq)                                     以 string 作为分隔符,将 seq 中所有的元素(的字符串表示)合并为一个新的字符串
# string.ljust(width)                                  返回一个原字符串左对齐,并使用空格填充至长度 width 的新字符串
# string.maketrans(intab, outtab])                     maketrans() 方法用于创建字符映射的转换表,对于接受两个参数的最简单的调用方式,第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标。
# max(str)                                             返回字符串 str 中最大的字母。
# min(str)                                             返回字符串 str 中最小的字母。
# string.partition(str)                                有点像 find()和 split()的结合体,从 str 出现的第一个位置起,把 字 符 串 string 分 成 一 个 3 元 素 的 元 组 (string_pre_str,str,string_post_str),如果 string 中不包含str 则 string_pre_str == string.
# string.replace(str1, str2,  num=string.count(str1))  把 string 中的 str1 替换成 str2,如果 num 指定,则替换不超过 num 次.
# string.rfind(str, beg=0,end=len(string) )            类似于 find()函数,不过是从右边开始查找.
# string.rindex( str, beg=0,end=len(string))           类似于 index(),不过是从右边开始.
# string.rjust(width)                                  返回一个原字符串右对齐,并使用空格填充至长度 width 的新字符串
# string.rpartition(str)                               类似于 partition()函数,不过是从右边开始查找.
# string.split(str="", num=string.count(str))          以 str 为分隔符切片 string,如果 num有指定值,则仅分隔 num 个子字符串
# string.splitlines(num=string.count('\n'))            按照行分隔,返回一个包含各行作为元素的列表,如果 num 指定则仅切片 num 个行.
# string.translate(str, del="")                        根据 str 给出的表(包含 256 个字符)转换 string 的字符,要过滤掉的字符放到 del 参数中
更多方法

5.同行显示

print ("Hello World!",end = "")
print ("Hello World!",end = "")

# end 控制段落最后
# windows默认为 \r\n,Linux默认为 \n,mac默认为 \r

6.字符串拼接

name = 'Hans'
age = '27'

# 逗号拼接
print ('my name is',name,'and I am',age,'years old')

# 加号拼接
print ('my name is'+name+'and I am'+age+'years old')

# 占位符拼接(推荐使用)
print ('my name is %s and I am %s years old'%(name,age))

List(列表)

列表的常用操作:增、删、改、查

1.创建列表

name = ['Hans','Jack','Tony','Peter']
name1 = list(['Hans','Jack','Tony','Peter'])

2.增加

name = ['Hans','Jack','Tony','Peter']

name.append('Joe')      #在列表末尾添加元素 ['Hans', 'Jack', 'Tony', 'Peter', 'Joe']
name.insert(0, 'Ben')   #在列表中插入元素 ['Ben', 'Hans', 'Jack', 'Tony', 'Peter']

  append()方法可以动态地创建列表,例如,创建一个空列表,在使用该方法添加元素

3.删除

name = ['Hans','Jack','Tony','Peter']

name.remove('Hans')   #不知道索引,知道元素值时使用 ['Jack', 'Tony', 'Peter']

n = name.pop(1)       #如果不加索引值,删除列表最后一个元素 ['Hans', 'Tony', 'Peter']
print(n)              #删除的元素可以储存在变量以便继续使用 Jack

del name[2]           #通过元素在列表中的位置删除 ['Hans', 'Jack', 'Peter']

name.clear()          #清空列表 []

  remove()方法只删除第一个指定的元素,如果要删除的元素在列表中重复,则需要使用循环

4.修改

name = ['Hans','Jack','Tony','Peter']

name[1] = 'Joe'             #对指定元素进行修改 ['Hans','Joe','Tony','Peter']
name[1:3] = ['Joe', 'Ben']  #同时修改两个元素 ['Hans', 'Joe', 'Ben', 'Peter']

5.查询

name = ['Hans','Jack','Tony','Peter']

name[1]         #取第二个元素 Jack
name[1:]        #取到最后一个元素 ['Jack','Tony','Peter']
name[1:-1]      #取到倒数第二个元素 ['Jack','Tony']
name[0:-1:2]    #最后的2为步长,从左到右隔一个去取 ['Hans','Tony']
name[3::-2]     #第4个元素开始从右到左隔一个去取 ['Peter', 'Jack']

6.其他操作

6.1 sort() 对列表进行永久性排序

letter = ['c','a','d','b']

letter.sort()               #对列表进行永久性排序 ['a', 'b', 'c', 'd']
letter.sort(reverse=True)   #反向排序 ['d', 'c', 'b', 'a']

6.2 sorted() 对列表进行临时性排序

letter = ['c','a','d','b']

print(sorted(letter))               #对列表进行临时性排序 ['a', 'b', 'c', 'd']
print(sorted(letter,reverse=True))  #临时性反向排序 ['d', 'c', 'b', 'a']

print(letter)                       #['c', 'a', 'd', 'b']

6.3 reverse() 反转列表元素的排列顺序

letter = ['c','a','d','b']

letter.reverse()    #['b', 'd', 'a', 'c']

6.4 更多方法

count      #统计某个元素在列表中出现的次数:
extend     #可以在列表的末尾一次性追加另一个序列中的多个值
index      #方法用于从列表中找出某个值第一个匹配项的索引位置

Tuple(元组)

  元组被称为只读列表,即数据可以被查询,但不能被修改,所以,列表的切片操作同样适用于元组,元组写在小括号()里,元素之间用逗号隔开,虽然tuple的元素不可改变,但它可以包含可变的对象,比如list列表。

  构造包含 0 个或 1 个元素的元组比较特殊,所以有一些额外的语法规则:

tup1 = ()    # 空元组
tup2 = (20,) # 一个元素,需要在元素后添加逗号

作用:

  1.对于一些数据我们不想被修改,可以使用元组;

  2.另外,元组的意义还在于,元组可以在映射(和集合的成员)中当作键使用——而列表则不行;元组作为很多内建函数和方法的返回值存在。 

Dictionary(字典)

描述

  字典是python中唯一的映射类型,采用键值对(key-value)的形式存储数据。

  特点:

      1.无序

      2.键唯一

1.创建字典

dic = {'name':'alex'}

dic1 = dict((('name','alex'),))

2.增加

# 方法一
dic1 = {'name':'alex'}
dic1['age'] = 18 #通过赋值方式增加
print(dic1)

# 方法二
dic1.setdefault('age',34) #键存在,不改动
print(dic1)

#键存在,不改动,返回字典中相应的键对应的值
ret = dic1.setdefault('age',34) 
print(ret) #返回值为18

#键不存在,在字典中增加新的键值对,并返回相对应的值
ret1 = dic1.setdefault('hobby','girl') 
print(ret1) # 返回值为'girl'

3.删除

dic5 = {'name': 'alex', 'age': 18}

#方法一:
del dic5['name']    #del方法:删除键值对

print(dic5)

#方法二:
dic5.clear()    #.clear方法:将字典内容清空

print(dic5)

#方法三:
res = dic5.pop('age')   #pop方法:根据Key删除键值对

print(dic5)

print(res)  #返回值:返回删除的键值对

#方法四:
a = dic5.popitem()  #随机删除某组键值对,并以元组方式返回

print(a,dic5)

4.修改

dic3 = {'name':'alex','age':18,'hobby':'girl'}

dic3['age'] = 55

print(dic3)

#将dic4字典中的键值对更新到dic3中,如果键值重复,则覆盖
dic3 = {'name': 'alex', 'age': 18}

dic4 = {'sex': 'male', 'hobby': 'girl', 'age': 36}
dic3.update(dic4)
print(dic3)

5.查询

dic3 = {'name':'alex','age':18,'hobby':'girl'}

dic3['name'] #通过键查找值

list(dic3.keys()) #查找字典中所有的键

list(dic3.values()) #查找字典中所有的值

list(dic3.items()) #查找字典中所有的键值对 

6.其他操作

  6.1 dict.fromkeys

d1=dict.fromkeys(['host1','host2','host3'],'Mac')
print(d1)
 
d1['host1']='xiaomi'
print(d1)
#######
d2=dict.fromkeys(['host1','host2','host3'],['Mac','huawei'])
print(d2)
d2['host1'][0]='xiaomi'
print(d2)

  6.2 d.copy() 对字典 d 进行浅复制,返回一个和d有相同键值对的新字典

  6.3 字典的嵌套

  6.4 sorted(dict) : 返回一个有序的包含字典所有key的列表

dic={5:'555',2:'222',4:'444'}
print(sorted(dic))          #对键排序并返回
print(sorted(dic.values())) #对值排序并返回
print(sorted(dic.items()))  #对键值对排序并返回

  6.5 字典的遍历

dic5={'name': 'alex', 'age': 18}
 
for i in dic5:
    print(i,dic5[i])
 
for items in dic5.items():
    print(items)
for keys,values in dic5.items():
    print(keys,values)

Set(集合)

集合是一个无序的,不重复的数据组合,它的主要作用如下:

  • 去重,把一个列表变成集合,就自动去重了
  • 关系测试,测试两组数据之前的交集、差集、并集等关系
s = set([3,5,9,10])      #创建一个数值集合  
  
t = set("Hello")         #创建一个唯一字符的集合  


a = t | s          # t 和 s的并集  
  
b = t & s          # t 和 s的交集  
  
c = t – s          # 求差集(项在t中,但不在s中)  
  
d = t ^ s          # 对称差集(项在t或s中,但不会同时出现在二者中)  
  
   
  
基本操作:  
  
t.add('x')            # 添加一项  
  
s.update([10,37,42])  # 在s中添加多项  
  
   
  
使用remove()可以删除一项:  
  
t.remove('H')  
  
  
len(s)  
set 的长度  
  
x in s  
测试 x 是否是 s 的成员  
  
x not in s  
测试 x 是否不是 s 的成员  
  
s.issubset(t)  
s <= t  
测试是否 s 中的每一个元素都在 t 中  
  
s.issuperset(t)  
s >= t  
测试是否 t 中的每一个元素都在 s 中  
  
s.union(t)  
s | t  
返回一个新的 set 包含 s 和 t 中的每一个元素  
  
s.intersection(t)  
s & t  
返回一个新的 set 包含 s 和 t 中的公共元素  
  
s.difference(t)  
s - t  
返回一个新的 set 包含 s 中有但是 t 中没有的元素  
  
s.symmetric_difference(t)  
s ^ t  
返回一个新的 set 包含 s 和 t 中不重复的元素  
  
s.copy()  
返回 set “s”的一个浅复制
更多方法

 

posted @ 2018-01-25 00:44  皮蛋小顽童  阅读(341)  评论(0编辑  收藏  举报