zoukankan      html  css  js  c++  java
  • python基础之二

    这周写的有点晚了,培训的作业写得头都大了,原来以为写2天就能写完,结果自己加了点功能居然搞了4天。。。

    第二天的培训内容基本在第一天的博客里就有了,提前看了下视频做了点记录,就把第二天的培训内容要点写一些吧,所以这周的笔记应该不是很多。废话不说了,开整。

    上周要点基本就讲了下列表、字典和运算符之类的。


    本周亮点内容:

    常量 

    常量顾名思义就是不会频繁变动的变量,为了便于别的程序员读懂你的代码,最好将常量定义以全部大写的方式来呈现,也可说业内潜规则吧,类似于变量的驼峰式和下划线命名规则。比如:

    CHINA='中国'

    列表


    列表中,字符串用引号表示,不带引号的为变量,print列表时,列表会将变量自动转化为变量对应的字符串:

    name='ccorz'
    l1=[1,'orz',name,'python']
    print(l1)

    结果:

    [1, 'orz', 'ccorz', 'python']

    列表删除

    除了list.remove(),还可用del ,del同样适用于变量,列表,字典等等,也可删多个:

    name='ccorz'
    del name  #可删变量
    l1=[1,'orz',name,'python']
    print(l1)

    结果:

    Traceback (most recent call last):
      File "C:/Users/Shane/PycharmProjects/test/111111.py", line 71, in <module>
        l1=[1,'orz',name,'python']
    NameError: name 'name' is not defined

    同样删除列表中的元素:

    name='ccorz'
    l1=[1,'orz',name,'python']
    print(l1)
    del l1[0]  #删除单个元素
    print(l1)
    del l1[0:2] #删除多个
    print(l1)

    结果:

    [1, 'orz', 'ccorz', 'python']
    ['orz', 'ccorz', 'python']
    ['python']

    列表删除还有pop(),其中remove为删除元素,pop()为删除列表的索引:

    name='ccorz'
    l1=[1,'orz',name,'python']
    print(l1)
    print(l1[:])  #list[:} 取列表中的所有元素
    l1.pop()    #pop()无指定的话,删除最后一个元素,同pop(-1)
    print(l1)
    l1.pop(1)
    print(l1)
    l1.remove('ccorz')
    print(l1)

    结果:

    [1, 'orz', 'ccorz', 'python']
    [1, 'orz', 'ccorz', 'python']
    [1, 'orz', 'ccorz']
    [1, 'ccorz']
    [1]

    pop比如:

    name='ccorz'
    l1=[1,'orz',name,'python']
    l1.append('haha')
    print(l1)
    l1.insert(1,'goo')
    print(l1)

    结果:

    [1, 'orz', 'ccorz', 'python', 'haha']
    [1, 'goo', 'orz', 'ccorz', 'python', 'haha']
    [1, 'goo', 'orz', 'ccorz', 'python']

    列表排序

    sort()可将列表排序,但在py3中,数字和字符串同时出现在列表中时,是无法排序的

    li=[1, 'goo', 'orz', 'ccorz', 'python', 'haha',2,3,6]
    li.sort()
     File "C:/Users/Shane/PycharmProjects/test/111111.py", line 79, in <module>
        li.sort()
    TypeError: unorderable types: str() < int()

    其实sorted,http://blog.chinaunix.net/uid-20775448-id-4222915.html 这有具体的说明,慢慢研究

    字符串的合并

    都说是万恶的加号‘+’,能不用就不用,那就用join,对象可谓字符串,列表等等

    a='x'.join('abc')  #前面是字符串连接字符或者符号,后面是字符串
    print(a)
    li=['goo', 'orz', 'ccorz', 'python', 'haha']
    print('x'.join(li))
    axbxc
    gooxorzxccorzxpythonxhaha

    字典

    dict.items() 数据量较大时比较耗时,故不推荐使用,需要注意的是,items()  keys()  values() 返回值都是一个列表 

    d1={'name':'ccorz','age':18,'company':'it'}
    d2=d1.items()
    
    print(d1)
    print(d2)



    结果:

    {'company': 'it', 'age': 18, 'name': 'ccorz'}
    dict_items([('company', 'it'), ('age', 18), ('name', 'ccorz')])

    dic.setdefault(‘asdfsad’,’test‘) 如果没有key,设置一个对应value,如果存在,返回其key的值

    d1={'name':'ccorz','age':18,'company':'it'}
    res=d1.setdefault('123')
    print(res)
    res2=d1.setdefault('xxxx','1111')
    print(res2)
    print(d1)
    res3=d1.setdefault('name','shane')
    print(res3)

    结果:

    None
    1111
    {'company': 'it', 'xxxx': '1111', 'age': 18, 'name': 'ccorz', '123': None}
    ccorz

    dic.fromkeys([1,2,3,4],’test’)  只是借用字典这个导入,对原来字典并没什么卵用

    d1={'name':'ccorz','age':18,'company':'it'}
    res=d1.fromkeys((1,2,3,1),'test')
    print(res)  #只是借用字典的功能而已
    print(d1)  #结果并没改变原来的字典

    结果:

    {1: 'test', 2: 'test', 3: 'test'}
    {'name': 'ccorz', 'age': 18, 'company': 'it'}

    dic.pop(’testkey’)  删除key以及对应的值  等同于del dic(’testkey’) 

    d1={'name':'ccorz','age':18,'company':'it'}
    
    d1.pop('name')
    print(d1)

    结果:

    {'company': 'it', 'age': 18}

    退出操作时,可用exit('bye!baby....')直接显示回显

    exit('bye.11.....')
    bye.11.....

    运算符优先级别:基本和数学算法类似,再不济我就加圆括号可好。。。。。。。,不抄了,直接扣图。。。。

    最后有一个比较有趣的,记录下来,以后判断类型要用type,不能直接用变量或者字符串直接判断

    a=[1,2,3,5,]
    print(a is list)
    print(type(a) is list)
    print('333' is str)
    print(type('333') is str)

    注意看结果:

    False
    True
    False
    True

    基本就这些了,打完,收工。。。。。

  • 相关阅读:
    【机器学习】机器学习12个关键经验教训
    【机器学习】24个终极项目提升您的机器学习知识和技能
    2018-12-21-WPF-弹出-popup-里面的-TextBox-无法输入汉字
    2019-10-31-C#-dotnet-获取整个局域网的-ip-地址
    2018-11-26-win10-uwp-获取窗口的坐标和宽度高度
    2019-5-21-dotnet-core-使用-CoreRT-将程序编译为-Native-程序
    2019-5-21-Roslyn-使用-Directory.Build.props-管理多个项目配置
    2019-2-26-SublimeText-快速打开当前文件的文件夹
    2019-2-18-VisualStudio-给项目添加特殊的-Nuget-的链接
    2019-8-31-dotnet-如何在-Mock-模拟-Func-判断调用次数
  • 原文地址:https://www.cnblogs.com/ccorz/p/5510695.html
Copyright © 2011-2022 走看看