zoukankan      html  css  js  c++  java
  • Python学习笔记(一)数据类型

    一.整型和浮点型

        Python可以处理任意大小的整数,当然包括负整数,在程序中的表示方法和数学上的写法一模一样  

    1 age=10
    2 num=-35
    3 score=98.8

    二.布尔类型

       布尔值和布尔代数的表示完全一致,一个布尔值只有TrueFalse两种值,要么是True,要么是False,在Python中,可以直接用TrueFalse表示布尔值(请注意大小写)

    1 a = True
    2 b = False

    三.列表和列表操作

        列表是 我们常用的一种数据类型之一,list是一种有序的集合,可以随时添加和删除其中的元素。列表也叫数组,列表定义,使用[]即可。

        比如,列出班里所有同学的名字,就可以用一个list表示, 列表里面也可以再套列表。

        列表中的元素,下标从0开始计数,比如list1中四个元素,那么他的第一个元素的下标为0,第二个元素的下标为1,依次类推,所以list1[0]输出的是第一个元素1。列表中最后一个元素的下标为-1,所以list2[-1][0]输出的是“羊”这个元素,list3[-1][1]输出的是500这个元素。

        

    1 list1 = [1,2,3,4]#一维数组
    2 list2 = ['','',['','']] #二维数组
    3 list3 = ['hello','apple',['banana',500,['OK','30']]]#三维数组
    4 # print(list1[0])#最前面一个元素的下标是0,最后面一个元素的下标是-1
    5 # print(list2[-1][0])
    6 # print(list3[-1][1])

       对于列表的操作,分别有增、删、改、查

       增:

    1 cities = []
    2 cities.append('北京')#在列表末尾增加一个元素
    3 cities.insert(0,'上海')#在列表指定位置增加元素
    4 cities.append('广州')
    5 print(cities)

       删:

    1 # cities.pop(0)#删除指定位置的元素
    2 # cities.remove('广州')#删除指定元素
    3 # cities.clear()#清空列表
    4 # del cities[-1]#删除指定位置的元素

       改:

    1  cities[1] = '南京'#修改的时候如果指定的下标不存在会报错

      查:

    1 print(cities[0])#输出指定位置的元素
    2 print(cities.index('北京'))#获取指定元素的下标,如果找不到那个元素会报错
    3 print(cities.count('广州'))#查看元素在这个list里出现了几次

    列表的一些内置方法

     1 list4 = ['python','jmeter','postman','linux','mysql']
     2 print(list4.reverse())#把这个list反转一下,输出的结果是None
     3  print(list4)#输出的是反转后的list
     4 
     5 list5=[8,23,12,86,34,10,5]
     6 print(list5.sort())#排序  升序
     7 print(list5)
     8 print(list5.sort(reverse=True))#排序 降序
     9 print(list5)
    10 
    11 print(list4+list5)#合并两个list
    12 print(list4.extend(list5)) #合并列表,把list5的值加到list4后面 13 print(list4*2)#将list复制 14 print(list5*2)#将list复制,并不是将里面数值乘2

    切片是list取值的一种方式

     1 nums = [14,7,23,56,34,18]
     2 print(nums[0])#取下标为0的元素
     3 print(nums[1:3])#取小标1至下标3之间的值,包括1,不包括3
     4 print(nums[1:-1])#取小标1至-1的值,不包括-1
     5 print(nums[1:])#取从下标为1的元素以及后面的所有元素
     6 print(nums[:4])#取下标0至4的值,不包括4
     7 print(nums[:])#取所有的
     8 
     9 #加上步长如下所示:
    10 nums1=[1,2,3,4,5,6,7,8,9,10]
    11 print(nums1[::2])#这个代表取所有元素,每隔2个元素取一个
    12 #输出[1, 3, 5, 7, 9]
    13 print(nums1[1:8:3])#代表取第二个元素开始,到第八个结束,隔3个取一次
    14 #输出[2, 5, 8]

    list循环:

    1 lists = [
    2     '张流量','李wifi','王路由器','牛网线',[1,2,3,4]
    3          ]
    4 for name in lists:  #for循环在循环可迭代对象的时候,每次循环的是里面的每一个元素
    5     if type(name)==list:  #判断一个变量的类型
    6         for i in name:
    7             print(i)
    8     print(name)

    四.元组

    元组也是一个list,他和list的区别是,元组里面元素无法修改

    如果元组里面 只有一个元素的话,那么你必须在这个元素后面加一个逗号

    元组也可以进行循环、切片、下标取值,但无法修改值

    1 t = (1,2,3,4,5,6,2)
    2 print(type(t))
    3 print(t[0]) #对元组进行下标取值
    4 print(t[:4]) #对元组进行切片取值
    5 for i in t:
    6     print(i)
    7 print(t.index(2)) #找到元素的下标
    8 print(t.count(2)) #找到元素的个数
    1 k=('abc')
    2 print(type(k))
    3 #输出类型为<class 'str'>
    4 m=('abc',)
    5 print(type(m))
    6 #输出类型为<class 'tuple'>

    五.字典

    Python内置了字典,dict使用键-值(key-value)存储,具有极快的查找速度。举个例子,假设要根据同学的名字查找对应的成绩,如果用list实现,需要两个list:一个存储姓名names,一个存储成绩score。给定一个名字,要查找对应的成绩,就先要在names中找到对应的位置,再从scores取出对应的成绩,list越长,耗时越长。如果用dict实现,只需要一个“名字”-“成绩”的对照表,直接根据名字查找成绩,无论这个表有多大,查找速度都不会变慢。

    1 d = {'Michael':88,'Mary':97,'Kevin':92}
    2 print(d['Michael'])
    3 print(d.get('Mary'))#取不到这个key的话,就是None
    4 print(d.get('Aimee',99)) #如果取不到这个key的话,默认就是99
    5 print(d.get('Aimee')#如果key不存在,会报错

    字典的特性:
    字典是无序的,因为它没有下标,用key来当索引,所以是无序的
    字典的key必须是唯一的,因为它是通过key来进行索引的,所以key不能重复,天生就去重

    字典的增删改查:

    增加:

    1 d['Aimee']=100
    2 d.setdefault('Linda',89)
    3 d.setdefault('Mary',100)#如果key存在的话,不会修改原来key对应的value值
    4 print(d)
    5 #输出{'Kevin': 92, 'Linda': 89, 'Michael': 88, 'Aimee': 100, 'Mary': 97}
    6 d['Mary'] = 100#如果key存在的话,会修改原来key对应的value值
    7 print(d)
    8 #输出{'Kevin': 92, 'Linda': 89, 'Michael': 88, 'Aimee': 100, 'Mary': 100}

    修改:

    1 d['Aimee'] = 88.88

    删除:

    1 d.pop('Kevin')#删除指定key
    2 d.popitem()#随机删除一个key
    3 del d['Mary']#删除指定key
    4 d.clear()#清空字典

    查找:

    1 infos = {'marry': [18, 18612512981, '北京'], 'amy': [20, 18612512991, '山东'], 'lily': [25, 18612532981, '河南']}
    2 infos.get('marry')#获取marry的信息,这种方式如果key不存在的话,会返回None
    3 infos['Marry']#这种方式如果key不存在的话会报错
    4 marry in infos#判断marry是否在这个字典中,返回True或False

    字典的内置方法:

    1 print(d.keys())#获取到字典所有的key
    2 print(d.values())#获取到字典所有的value
    3 print(d.items())#获取到字典所有的k-v
    4 d2={'stu1':95,'stu2':86,'Aimee':66}
    5 d.update(d2)#更新字典值,如果key存在的话就更新,不存在的话就添加

    字典循环:

    1 d = {'Michael':88,'Mary':97,'Kevin':92}
    2 for k in d:
    3     print(k,d[k])#打印key和value的值,推荐使用这种方式,速度快
    4 
    5 for k,v in d.items():
    6     print(k,v)#打印key和value的值,这种方式不推荐,因为会把字典转换成列表

    字典排序:

    d = {'a':8,'b':2,'c':3}  #字典是无序,直接对字典排序是不存在的。
    print(d.items())     #每次运行打印的结果顺序都有可能不同
    res = sorted(d.items(),key=lambda x:x[0]) #sort,循环调用,按key排序
    res = sorted(d.items(),key=lambda x:x[1])  #按value排序
    print(res)

    小栗子:

     1 people = {
     2     '张三':{
     3         'age':18,
     4         'money':200000,
     5         'clothes':'100套',
     6         'hzp':'n多',
     7         'shoes':['nike','addis','lv','chanle']
     8     },
     9     '李四':{
    10         '金库':'2000w',
    11         'house':['三环一套','4环2套'],
    12         'cars':    {
    13                 'japan':['普拉多','兰德酷路泽'],
    14                 'usa':['林肯','凯迪拉克','福特'],
    15                 'china':['五菱宏光','qq','红旗']
    16             }
    17     }
    18 }
    19 people['张三']['shoes'].append('匡威')
    20 people['李四']['cars']['usa'].append('牧马人')
    21 people['张三']['money'] = people['张三']['money']+500
    22 people['张三']['money']+=900
    23 print(people)
    View Code

    六.字符串或串(String)是由数字、字母、下划线组成的一串字符。可以存任意类型的字符串,比如名字,一句话等等。

    1 name = '毛毛球'
    2 word = 'Hello World'

    字符串常用方法:

     1 str='   我是python爱好者  
    
    
    
    
    '
     2 b = str.strip('chars')  #移除字符串str头尾指定的字符chars,返回移除字符串头尾指定的字符生成的新字符串
     3 c = str.lstrip()   #返回截掉字符串左边的空格或指定字符后生成的新字符串
     4 d = str.rstrip()   #返回删除 string 字符串末尾的指定字符后生成的新字符串(默认为空格)
     5 words = 'today is a nice day'
     6 print(words.strip('is'))#如果strip方法指定一个值的话,那么会去掉这两个值
     7 print(words.count('a')) #统计字符串出现的次数
     8 print(words.index('n'))#找下标,如果元素找不到的话,会报错
     9 print(words.find('z'))#找下标,如果元素找不到的话,返回-1
    10 print(words.replace('day','DAY')) #替换字符串
    11 url = 'http://www.nnzhp.com'
    12 str = 'asdas32423'
    13 print(url.startswith('http'))  #判断是否以某个字符串开头
    14 print(url.endswith('.jpg'))  #判断是否以某个字符串结尾
    15 print(words.upper())  #变成大写的
    16 print(words.lower())  #变成小写的
    17 print(str.isalpha())  #判断字符串是否全为字母
    18 print(str.isalnum())  #判断是否包含字母和数字,它是只要有字母或者有数字就返回true
    19 print(str.isupper())  #判断字符串是否全是大写
    20 print(str.islower())  #判断字符串是否全是小写
    21 print(words.isdigit())#判断字符串是否为纯数字
    22 import string
    23 print(string.ascii_letters) #所有的大写字母和小写字母
    24 print(string.ascii_lowercase) #所有的小写字母
    25 print(string.ascii_uppercase) #所有的大写字母
    26 print(string.punctuation) #所有的特殊字符
    27 print('欢迎登录'.center(50,'*')) #*加‘欢迎登录’总共50个字符,把‘欢迎登录’放中间
    28 
    29 l=['zhang','liu','liang']
    30 res = ','.join(l)  
    #1、它把一个list变成了字符串 31 #2、通过某个字符串把list里面的每个元素连接起来 32 #3、只要是可以循环的,join都可以帮你连起来 33 names='abcd' 34 print(list(names)) #把字符串names转换为list 35 name_list = names.split(‘b’)#根据某个字符串,分割字符串,什么也不传的话,是以空格分割的 36 print(name_list)
    1 #把字符串以某个标记分割,存储成一个list
    2 str = '我|家|有|个|乖|宝|贝'
    3 list = str.split('|')
    4 print(list)
    5 #>>>>['', '', '', '', '', '', '']
    1 #把list以某个标记连接,存储成一个字符串
    2 list = ['', '', '', '', '', '', '']
    3 words = ''.join(list)
    4 print(words)
    5 #>>>>我家有个乖宝贝
    6 test = '**'.join(list)
    7 print(test)
    8 #>>>>我**家**有**个**乖**宝**贝

    六.格式化输出

           什么是格式化输出呢,就是说把你的输出都格式化成一个样子的,比如说登录的欢迎信息,都是welcome to login,Marry. 每个用户登录都是这样欢迎,但是每个用户的用户名都是一样的,你不能一个用户就写一行代码吧,这就需要用到格式化输出了,有三种方式,第一种是用“+”连接,直接把输出的字符串和变量连接起来就可以了;第二种是用占位符,占位符有常用的有三种,%s、%d和%f,%s是后面的值是一个字符串,%d是后面的值必须是一个整数,%f后面是小数;第三种是使用{}和fromat方法,这三种呢,官方推荐是使用format方法,不推荐使用第一种,第一种用加号的,会在内存里面开辟多个内存空间,而后面两种是只开辟一块内存空间,使用方式如下: 

    name = input('请输入你的名字:')
    print('你的名字是'+name) #使用加号连接
    print('你的名字是%s'%name)#使用占位符  
    print('你的名字是{your_name}'.format(your_name=name)) #使用format格式化输出,{}里面的名字可以随便写但是要和后面的format中的名字保持一致,然后再把你前面定义的变量写到等号后面就可以了。
    age = 18
    print('我的名字是%s,年龄是%d岁.'%(name,age))#这种是里面有多个格式化内容的,前面那个是字符串,后面这个是整数,多个变量的后面跟值的时候必须要加上括号
  • 相关阅读:
    OCI读取单条记录(C)
    共享内存shmget shmat shmdt
    Linux系统下的多线程编程入门
    如何让errno多线程/进程安
    linux的mount(挂载)命令详解
    取得系统时间并以BCD形式保存到字符串中
    电脑上的搜索功能用不了了,怎么办?
    如何建立Linux下的ARM交叉编译环境
    C#网络编程之Http请求
    深入了解Oracle前滚恢复rolling forward(一)
  • 原文地址:https://www.cnblogs.com/mululu/p/8652779.html
Copyright © 2011-2022 走看看