zoukankan      html  css  js  c++  java
  • python基础学习

    (一)Python基础学习

    Num01:python的基本数据类型

    字符串:可进行拼接和截取

    ②数字:int,float,complex(复数)

    涉及到格式转换:int(x)转换为整数,float(x)转换为浮点数,complex(x)将x转换为一个复数,实部为x,虚部为0

    运算注意:a/b得到的是一个浮点数,a//b得到的是:整数除法返回向下取整后的结果。a**b代表:a的b次幂

    ③列表(list)

    形如:list=['Python','Web','Script']可对其进行访问和修改与删除

    删除:del list[2]就将Script删除掉

    a=[0,1,2,3,4]
    a[0]=9
    b=[5,6,7,8]
    del b[2]
    print(a[:3])
    print(b)
    View Code

    输出:

    [9, 1, 2]
    [5, 6, 8]

    ④Tuple(元组)

    形如:tup1 = ('Google', 'Runoob', 1997, 2000)

    我们不能修改里面的元素值,但可以进行访问和与其他的字符串进行拼接,元组有一些内置函数:len(tuple)计算元组的元素个数,max,min返回元组中的最大值和最小值。

    ⑤字典(Dictionary)

    含有key和value,和map是一样的

    # #字典;键与值的集合
    dict = {}
    dict['one'] = "1 - 菜鸟教程"
    dict[2] = "2 - 菜鸟工具"
    
    tinydict = {'name': 'runoob', 'code': 1, 'site': 'www.runoob.com'}
    
    print(dict['one'])  # 输出键为 'one' 的值
    print(dict[2])  # 输出键为 2 的值
    print(tinydict)  # 输出完整的字典
    print(tinydict.keys())  # 输出所有键
    print(tinydict.values())  # 输出所有值
    print(dict.keys())  # 输出所有键
    print(dict.values())  # 输出所有值
    print ("我叫 %s 今年 %d 岁!" % ('小明', 10))
    View Code

    输出:

    1 - 菜鸟教程
    2 - 菜鸟工具
    {'name': 'runoob', 'code': 1, 'site': 'www.runoob.com'}
    dict_keys(['name', 'code', 'site'])
    dict_values(['runoob', 1, 'www.runoob.com'])
    dict_keys(['one', 2])
    dict_values(['1 - 菜鸟教程', '2 - 菜鸟工具'])
    我叫 小明 今年 10 岁!

    Num02:while和if,elif,else与随机数的使用

    一个猜数字的demo

    #while和if elif和随机数的使用
    k=random.randint(0,100)
    print(k)
    num=-1
    while(num!=k):
        num = int(input("请输入你猜的数字:
    "))
        if(num==k):
            print("恭喜你猜对了!")
            break
        elif(num>k):
            print("猜大了!")
        else:
            print("猜小了")
    View Code

    判断平年还是闰年

    #判断闰年与平年
    year = int(input("输入一个年份: "))
    if (year % 4) == 0:
       if (year % 100) == 0:
           if (year % 400) == 0:
               print("{0} 是闰年".format(year))   # 整百年能被400整除的是闰年
           else:
               print("{0} 不是闰年".format(year))
       else:
           print("{0} 是闰年".format(year))       # 非整百年能被4整除的为闰年
    else:
       print("{0} 不是闰年".format(year))
    View Code

    Num03:函数的使用

    斐波那契数列求解:

    def fic(k):
        if(k==1):
            return 1
        elif(k==2):
            return 1
        else:
            return fic(k-1)+fic(k-2)
    
    c=int(input("请输入要查询的第几个斐波那契数:
    "))
    print(fic(c))
    View Code

    Num04:面向对象编程

    1.封装

    class Big():
        def __init__(self,name,age):
            self.name=name
            self.age=age
        def detail(self):
            print(self.name)
            print(self.age)
    
    obj1=Big('Tom','18')
    obj1.detail()

    通过封装的形似定义了一个Big类,在该类中可以通过各种函数来定义Big的各种行为和特性,这就是面向对象编程所需要的,会使对象的操作简单,有条理化。

    2.继承

    继承:子继承了父的某些特性

    猫:喵喵叫、吃、喝、拉、撒

    狗:旺旺叫、吃、喝、拉、撒

    我们将他们共同的特性整合到一起

    建立一个Animal:吃喝拉撒

    猫:喵喵叫(猫继承动物的功能)

    狗:汪汪叫(狗继承动物的功能)

    class Animal:
        def eat(self):
            print("%s 吃" %self.name)
        def drink(self):
            print("%s 喝" %self.name)
        def shit(self):
            print("%s 拉" %self.name)
        def prr(self):
            print("%s 撒" %self.name)
    class Cat(Animal):
        def __init__(self,name):
            self.name=name
        def cry(self):
            print('喵喵叫')
    class Dog(Animal):
        def __init__(self,name):
            self.name=name
        def cry(self):
            print('汪汪叫')
    c1=Cat('我家的小白猫')
    c1.eat()
    c1.cry()
    d1=Dog('胖子家的小黑狗')
    d1.eat()
    d1.cry()

    Num05:简单的入门级爬虫实验

    爬取我的博客园的第一篇博客的时间和标题

    分三步走:

    第一步:获取页面

    首先导入import requests,使用requests.get(link,headers=headers)获取网页

    注意:用requests的headers伪装成浏览器访问,我们要获得的信息在response.text里(就是网页的内容代码)

    第二步:提取想要的数据

    这里会用到BeautifulSoup这个库对爬下来的页面进行解析,将html代码转化为soup对象,接下来用find去寻找自己的数据

    第三步:存储数据

    存储到本地的txt文件,将获取的信息写入txt里,这里要特别注意格式encoding='utf-8',否则到txt里的东西会乱码

    from bs4 import BeautifulSoup
    import requests, sys
    import random
    #1.获取网页代码
    url = 'https://www.cnblogs.com/xiaofengzai/'  #请求地址
    headers = {'user-agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/74.0.3729.131 Safari/537.36'}#创建头部信息
    response =  requests.get(url,headers = headers)  #发送网络请求
    
    #print(response.text)
    #2.提取想要的数据
    soup=BeautifulSoup(response.text,"html.parser")
    title=soup.find("a",class_="postTitle2").text.strip()
    print(title)
    time=soup.find("div",class_="dayTitle").a.text.strip()
    print(time)
    #3.写入到文件里
    with open("title.txt","a+",encoding='utf-8') as f:
        f.write(time+":"+title)
        f.close()

    txt内容

    日期 开始时间 结束时间 中断时间 净时间 活动
    3/11 10:50 11:20 5 25 学习python的基本数据
    3/11 14:00 15:30 10 80 学习python的语法,函数以及面向对象
    3/11  16:00 17:30 5 85 对Python进行实战测试,巩固知识
    3/11 20:30 21:30 10 50 学习简单的爬虫并动手进行练习
    3/11 21:40 22:30 0 50 写博客,总结

    今日有效总代码量(Python):180行,总学习时间:290分钟

  • 相关阅读:
    公司财务(书籍学习过程总结)
    职场心理学-心理学第一天(非原创)
    (原创干货)自身管理-日常思考实战框架学习第八天
    (原创干货)融资、路演-日常思考实战框架学习第七天
    (原创干货)理财、投资-日常思考实战框架学习第七天
    (原创干货)理财、投资-日常思考实战框架学习第六天
    (原创干货)公司金融-日常思考实战框架学习第五天
    (原创干货)沟通、演讲-日常思考实战框架学习第四天
    虚拟机中给linux 系统添加硬盘以后,进行分区挂载
    基于Xshell使用密钥方式连接远程主机
  • 原文地址:https://www.cnblogs.com/xiaofengzai/p/12466067.html
Copyright © 2011-2022 走看看