• python基础篇


    http://www.cnblogs.com/yuanchenqi/articles/5782764.html

    一、变量

      1、定义:变量用于存储要在计算机程序中引用和操作的信息。他们还提供了一种以描述性名称标注数据的方法,所以我们的程序可以被读者和我们自己更清楚地理解。将变量视为容纳信息的容器是有帮助的。它们的唯一目的是将数据标记和存储在内存中。 然后可以在整个程序中使用此数据。

      2、声明变量:name="alex"

            上述代码声明了一个变量,变量名为: name,变量name的值为:"Alex Li"

      3、变量定义规则:

      • 变量名只能是 字母、数字或下划线的任意组合
      • 变量名的第一个字符不能是数字
      • 以下关键字不能声明为变量名
        ['and', 'as', 'assert', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'exec', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'not', 'or', 'pass', 'print', 'raise', 'return', 'try', 'while', 'with', 'yield']

      4、变量的赋值

    二、缩进

      缩进就是控制块,官方建议空四个空格,在很多语言里都是通过大括号来实现的,但是Python是通过空格

    三、注释

      单行注释:#

      多行注释:""" """或''' '''

    四、运算符

      1、算数运算符 +  -  *  /

      2、赋值运算符 =  +=  -=  *=  /=

      3、比较运算符 ==  >=  <=  !=  >  <  (一定是布尔值,用于循环)

      4、逻辑运算符 and(与)  or(或)  not(非)

      5、关系运算符 in  not in  (返回值是布尔值)

             例:print(2 in [1,2,3]

               True

      6、位运算符

    五、数据类型

      1、定义:计算机顾名思义就是可以做数学计算的机器,因此,计算机程序理所当然地可以处理各种数值。但是,计算机能处理的远不止数值,还可以处理文本、图形、音频、视频、网页等各种各样的数据,不同的数据,需要定义不同的数据类型。在Python中,能够直接处理的数据类型有以下几种

      所有的数据类型一定可以划分为两种:

        可变数据类型:列表,字典

        不可变数据类型:整形,元组,字符串

        不可变数据类型如下图:

        

        再比如:i=1(在内存中创建一个数据类型)

            i=2(并不是覆盖1,而是开辟一块新的空间,写上2)  

      2、数字(整形,浮点型,布尔类型)

      

      整形

      Python3中整形(int)就是长整型,在2.x版本中才有区分

      

      浮点型(float,double)

      科学计数法,是为了节省空间,比如无线循环和不循环小数如果一直存在去电脑会崩溃

      精度要求非常高的话使用double

      例:0.000123=1.23e^(-4)

      

      布尔值

      True=1,False=0,二者可进行运算,True+False=1

      3、字符串(string)

      创建2种(表达式和关键字):表达式:s="zhongguo"

                     关键字:s=str("zhongguo")#涉及到类

      字符串操作:

        查找  []  [:]   #序列都可以进行切片,如字符串列表元组

        去空:strip()#把字符串的开头和结尾的空格和制表符还有换行符去掉,括号里可以加参数

        拼接:s="hello"+"world"+"I"+"am"+"python"(拼接次数多的话,效率要低,因为字符串是不可变的,显示helloworld申请一块内存空间,然后又是helloworldI申请一段内存空间,然后又是helloworldIam申请一断内存空间,一次类推)

             "".join(iterable)#数字不能拼接,不是一个类型的不能拼接,""中可以加*,空格之类的其他东西

        分割:split(),正好与join相反是把字符串分割成一个列表,参数只要字符串中有的都可以加,还有最大分个数split(,)逗号后边可以规定分割次数

           splitlines是以换行符为分隔符的如果末尾有 的话不会显示,但split会显示

        

        find(找不到返回-1)

        "hello world".find("l")#打印后返回2

        "hello world".find("l",3)#打印后返回3

        

        index(找不到报错)

        "hello world".index("l",4)#返回后打印9

        

        replace

        "hello world".replace("world","python")#完全匹配,必须一对一匹配上 

        s="hello world"

        print(s.replace("world","python"))------------->hello python

        print(s)------------------------------------------>hello world

        因为字符串是不可变的,所以hello python是开辟了一块新的空间,之前的s还是指向hello world,而后边讲到的append针对的类型是可变的,是直接对列表(只举列表这一个例子)进行修改,没有返回值,也就意味着并没有开辟新的空间,直接打印原列表即可

        

        居中显示:print("hello world".center(50,"*"))#居中显示总共50个字符,不够的用*补上

             print("hello world".ljust(50,"*"))#靠左显示,右边用*补全,总共50个字符

        字符串的格式化输出:

         "hello %s"%"sb"---------->print后输出hello sb

         %s,给字符串占位  %d,给整形占位  %f,给浮点型数据占位,%.4f小数点后保留四位(占四位)

         "hello {0},his age is {1}".format("alex",34)#按索引位对应

         "hello {name},his age is {age}."format(name="wusir",age=30)#通过键值对(推荐)

         "hello {name},his age is {age}."format_map({"name":"agon","age":33})#通过字典

        

        关于数字判断:isdecimal(),isdigit(),isnumeric()--->返回True或者False

         isnumeric中1,一,I,壹都可以识别

        

        大小写:

        print("hello world".capitalize())----->Hello world

        print("hello world".title())------------>Hello World

        print("HEllO world".casefold())------->hello world

        print("HEllO world".lower())------->hello world

        

        expandtabs

        "HELLO world".expandtabs(20)更改 的空格数

        

        zfill:

        print("hello world".zfill(50))#其他位置都补0,内容右对齐

      

      4、列表  可迭代对象,能够进行for循环的就是可迭代对象

      创建:l=[1,"hello",[4,5],{"name":"egon"}]

         l2=list([1,23,3])

         查:切片[:]

         增:append()#可以追加字符串和列表,追加到最后,只能添加一个,不能添加多个

           print(l2.append("yuan"))#返回None因为列表为可变的,没有开辟新的空间,直接在原来的结果上进行了添加

           extend()#可以进行多个添加,如12.extend([7,8])如果是多序列的话参数必须是列表形式

           insert(2,66)#指定位置进行插入,插入的66索引值为2

         

         删:l2.pop(1)#pop参数为索引值,返回删掉的值

           l2.remove(23)#不知道索引值,通过内容删除

           del 12[2]#最霸道的删除

           del l2#可直接删掉列表   del l2[1,3]#可以分段删

         改:l2[0]="yuan"

         清空:l2.clear()#清空就是把里面的值全清空,效率低

            l2=[]#(推荐)与上面的不一样,这个是把l2重新指向了一个新的地址,所以和上面的内存地址肯定不一样

         计数:l2.count(3)#返回值是1,判断列表里有几个3

         长度:len(l2)#返回值是3,判断l2中有几个元素

         排序:sort  l3=[3,1,56,34]

                l3.sort()#.方法,默认reverse=False要从大到小排:l3.sort(reverse=True)

                print(l3)

            sorted   print(sorted(l3))#函数方法

         拷贝:深拷贝和前拷贝

      5、字典(哈希算法可哈希就是可以进行哈希算法 反之就是不可以 可以进行哈希算法的数据就是不可变类型的,如果是不可变的,在对对象本身操作的时候,必须在内存的另外地方再申请一块区域(因为老区域#不可变#),老的区域 就丢弃了(如果还有其他ref,则ref数字减1,类似unix下的hard-link)。如果是可变的,对对象操作的时候,不需要再在其他地方申请内 存,只需要在此对象后面连续申请(+/-)即可,也就是它的address会保持不变,但区域会变长或者变短。

    )无序的

        Python中唯一具有映射关系的数据类型,字典的查询速率要远高于列表,好比一页一翻得找和找到对应的页码直接找页码,但是字典的存储空间较大,比列表多了一张映射表,总之,是用空间取换取时间

        创建:d={"name":"alex","name":"egon"}#打印结果会以后面的结果为准,就是前边的被覆盖了,白写。键唯一且为不可变数据类型,如元组、字符串、整形

        查:d["name"]

          d.get("name",None)#推荐,如果字典里没有的话返回None,可以换成一些其他的东西比如False

          for i in dict循环遍历的是字典的key

          for i in dict:

            print("%s---->%s"%(i,d[i]))#格式化输出

        增:d["gao"]="luchuan"

        改:d["name"]="yuan"

        删:d.pop("1")#返回删掉的value值

      6、集合set  两个功能:去重,关系测试。 可变数据类型

         set集合内元素一定是不可变数据类型

         关系测试:s1={"hello",1,2,3}

              s2={1,2,("a","b")}

        求并集:print(s1.union(s2))

            print(s1|s2)#顺序没关系    

        求交集:print(s1.intersection(s2))

            print(s1&s2)

        求差集:print(s1.difference(s2))#s1中有的,s2中没有的

            print(s1-s2)

            print(s2.difference(s1))#s2中有的,s1中没有的

            print(s2-s1)

        求对称差集:print(s1.symmetric_difference(s2))#互相都没有的

              print(s1^s2)   

      7、元组tuple  (不能进行修改操作)

        查: 切片 [:] 

      

      8、循环中的注意点

      if和else、elif语句使用时需要注意一下两点:

        1.else、elif为子块,不能独立使用

        2.一个if语句中可以包含多个elif语句,但结尾只能有一个else语句

      else在while、for循环语句中的作用

        Python中,可以在while和for循环中使用else子句,它只是在循环结束之后才会被执行,如果同时使用了break语句那么else子句会被跳过。所以注意else子句和break语句不能同时使用

      9、三级菜单

    menu = {
        '北京': {
            '海淀': {
                '五道口': {
                    'soho': {},
                    '网易': {},
                    'google': {}
                },
                '中关村': {
                    '爱奇艺': {},
                    '汽车之家': {},
                    'youku': {},
                },
                '上地': {
                    '百度': {},
                },
            },
            '昌平': {
                '沙河': {
                    '老男孩': {},
                    '北航': {},
                },
                '天通苑': {},
                '回龙观': {},
            },
            '朝阳': {},
            '东城': {},
        },
        '上海': {
            '闵行': {
                "人民广场": {
                    '炸鸡店': {}
                }
            },
            '闸北': {
                '火车战': {
                    '携程': {}
                }
            },
            '浦东': {},
        },
        '山东': {},
    }
    
    current_layer = menu
    layer = []
    
    while True:
        for i in current_layer:  # 将当前层赋值给i
            print(i)
        choice = input(">:").strip()
        if not choice: continue
        if choice in current_layer:
            layer.append(current_layer)
            current_layer = current_layer[choice]
        elif choice == "b":
            if len(layer) != 0:
                current_layer = layer.pop()
            else:
                print("到顶了")
        elif choice == "q":
            exit("offer")
    

      10、简单购物车

    product_list = [["Iphone7",5800],#建立一个商品列表
                    ["Coffee",30],
                    ["Gedatang",10],
                    ["PythonBook",99],
                    ["bike",200]
    
                    ]
    shopping_cart = {}#建一个空字典,装东西,购物车空字典
    salary = int(input("input your salary:"))#工资是数字,所以要int()
    while True :#当工资是数字的时候,运行循环
        index = 0
        for product in product_list:#从商品列表中取出商品,价格列表
            print(index,product)#打印商品代号,商品和价格列表
            index += 1
        choice = input(">>:").strip()#选择商品对应的数字,stip后空格和Tab无效
        if choice.isdigit():#判断是否为数字
            choice = int(choice)#将数字转为整形
            if choice >= 0 and choice < len(product_list):#商品存在,如果数字大于等于0并且小于商品列表最大数
                product = product_list[choice]#取到商品
                if product[1] <= salary:#判断能否买得起,product包括商品和商品价格
                    #买得起
                    if product[0] in shopping_cart:#product[0]是商品名字,[1]是商品价格
                        shopping_cart[product[0]][1] +=1#购物车字典,以product[0]为key,value是
                    else:
                        shopping_cart[product[0]]=[product[1],1]#加入购物车,创建一条商品购买记录
                    salary -=product[1]#扣钱
                    print("已经把"+product[0]+"加入到你的购物车,您的余额还剩"+str(salary-product[1])+"元钱")
                else:
                    print("买不起,产品价格是"+ str(product[1]) +"你还差"+str(product[1]-salary)+"元钱")
            else:
                print("商品不存在!")
        elif choice == "q":
            print("-----已购买商品列表-----")
            id_counter = 1
            total_cost = 0#初始化一个总消费的变量
            print("id   商品  数量  单价  总价")
            for key in shopping_cart:
                print("%s	%s	%s	%s	%s"%(id_counter,
                                            key,
                                            shopping_cart[key][1],
                                            shopping_cart[key][0],
                                            shopping_cart[key][1]*shopping_cart[key][0]
                                            ))
                id_counter += 1
                total_cost += shopping_cart[key][1]*shopping_cart[key][0]
            print("您的总花费为:",total_cost)
            print("您的余额为:",salary)
            print("-----end-----")
            break
        else:
            print("无此选项")
    

      

  • 相关阅读:
    业务、技术和语言的关系
    查询优化一般原则
    软件构架师的特点(转与Rational Edge)
    VMware安装Vista虚拟机
    使能更改SubVersion日志信息
    清除数据库日志文件
    构建自定义活动以扩展您的工作流的作用范围(转载于MSDN)
    Delphi数据库通用模块及典型系统开发
    Windows Workflow Foundation 2 规则引擎简介
    设置STS服务器配置数据库
  • 原文地址:https://www.cnblogs.com/wuyongqiang/p/6662408.html
Copyright © 2020-2023  润新知