Python【day 15】基本數據類型-int str bool list

来源:https://www.cnblogs.com/wangtp/archive/2019/11/11/11832658.html
-Advertisement-
Play Games

'''''' ''' 1 python的定義 是一門弱類型的解釋性的高級編程語言 這裡的高級是相對低級(例如:彙編語言等) 高級編程語言和低級編程語言的區別 1、前者更接近於人的理解--字母組成的語法 2、後者更接近於計算器的理解--位元組碼、二進位 2 python的特點 人生苦短,我用python... ...


''''''
'''
1 python的定義
    是一門弱類型的解釋性的高級編程語言
    這裡的高級是相對低級(例如:彙編語言等)

    高級編程語言和低級編程語言的區別
    1、前者更接近於人的理解--字母組成的語法
    2、後者更接近於計算器的理解--位元組碼、二進位

2 python的特點
    人生苦短,我用python
    簡潔

3 為什麼學習python
    愛好,人工智慧,機器學習,大數據

4 python第一個程式
    print('hello world')
    方式1:在cmd中輸入python後,在交互命令行,輸入上述語句,enter
    方式2:在本地d盤新建一個hello.py的文件,將上述語句複製到.py文件中,保存後
           在cmd中,進入到d盤, 執行命令 python hello.py
    方式3:將上述語句寫入pycharm後,run

5 變數的概念
    變數是程式運行過程中產生的中間值--temp(暫存屬性,開闢一個記憶體空間,用於保存值)
        1、記憶體空間的名字就是變數的名字
        2、記憶體空間保存的值就是變數的值
        比如: a=10  變數名字就是a 變數的值是10

6 變數的命名規則:
    1、組成:數字、字母、下劃線組成
    2、開頭:不能是數字開頭
    3、關鍵字:不能是關鍵字,比如:list
    4、長度:不要太長
    5、中文:不要是中文
    6、有意義:要有意思(一看名字,就知道變數大概表示的意思)
    7、大小寫:嚴格區分大小寫
    8、寫法:推薦下劃線或者駝峰法命名
        下劃線:hello_world(單詞之間,下劃線分隔開)
        駝峰法:helloWorld  (首字母不大寫,第二個單詞開始,首字母大寫)

7 變數的數據類型
    1 int 整數  + - * / // bit_length()
    2 str 字元串
        1、表示方式 ' " \''' \"""   註意點:這裡的\ 表示轉義
            1 單引號''
            2 雙引號""
            3 三個單引號 ''' '''
            4 三個雙引號 """ """
        2、* 重覆
        3、+ 拼接
        4、%s 格式化
        5、索引和切片
            s1[start:end:step]  左閉右開
            1 start 起始索引號-下標
            2 end   結束索引號-下標 (取不到)
            3 start 步長(不寫,預設是1)

        6、常見內置方法
            1 upper()  轉換成大寫字母

            2 strip() 去掉字元串兩端的空白
               strip('ab')  去掉字元串兩端的'ab'

            3  replace(old,new,count)
                參數3 count表示從左到右替換的次數
                參數3不寫,預設是全部替換

            4  split() 把字元串拆分成幾個子字元串,每個子字元串作為列表的元素,返回的是列表
                預設分隔符是空格
                split('_') 分隔符是下劃線

            5  '_'.join() 把參數iterable中的字元串通過連接符'_'拼接成字元串
                寫法: '連接符'.join(iterable)
                註意點:
                    1 iterable中的元素必須是str,而不能是int
                    2 join不是字元串的內置方法

            6  startswith()
                寫法:s1.startwith('a')
                作用:判斷字元串是否以字母'a'開頭

            7 find index count
                寫法:s1.find('a')
                作用:從字元串s1中查找字元‘a’,返回索引號;如果找不到,就返回-1  --更健壯  推薦

                寫法:s1.index('a')
                作用:從字元串s1中查找字元‘a’,返回索引號;如果找不到,就報錯

                寫法:s1.count('a')
                作用:從字元串s1中統計字元'a'出現的次數,返回出現的次數int
                    如果是0次,代表沒有找到(也有查找的功能)
            8 isdigit()
                寫法:s1.isdigit()
                作用:判斷字元串是否是數字形式的,是的話,返回True

            9 len()
                寫法:len(s1)
                作用:返回字元串的長度

        7、字元串是iterable
            for i in s1:
                迴圈體(break continue)
            else:
                pass

        8、字元串的編碼方式
            1 ascii             8位 1個位元組
            2 gbk 國標碼 gb2312 16位 2個位元組
            3 unicode 萬國碼    32位 4個位元組
            4 utf-8 可變的unicode
                1 英文字元  8位 1個位元組
                2 歐洲字元 16位 2個位元組(德文、法文、西班牙文等字元)
                3 中文字元 24位 3個位元組
            字元串編碼後變成位元組bytes
                編碼-加密-壓縮
            位元組解碼後變成字元串
                解碼-解密-解壓
                bytes.decode()  #解碼

    3、bool 布爾類型
        取值:True False
        作用:用於判斷的
        類型轉換:
            False:0或者空('' [] () {} set() None)
                        空字元串、空列表、空元組、空字典、空集合、空None
                註意:空格、\r \n \t都是True
            True:除了上面的,其他都是True
            註意點:類型轉換False可以直接用於判斷
        備註:
            例子1
            content1 = input('請輸入你的名字:')  #輸入的是字元串
            if content1:  #判斷空  如果不輸入內容,直接回車,就提示-你沒有名字 註意點:和下麵行的結果不一樣
            # if content1 == '':  #如果不輸入內容,直接回車,就列印-你的名字是
                print('你的名字是 ',content1)
            else: #如果你什麼都沒有輸入,這個content1就是空字元串
                print('你沒有名字')

            例子2
            li1 = [1,2,3]
            if li1:  #這裡就是在判斷列表是否為空, 和下麵行等效
            # if li1 == []:
                print(li1)
            else: #
                print('空列表')

    4、列表 list
        表示:[],元素之間是逗號隔開
        概念:列表是一個容器,可以存放任意數據類型
            和其他開發語言的數組array類似
        特點:
            1、列表是可變的
            2、列表由索引和切片功能
        常見操作:
            1 增
                1 append(元素值)
                    在列表最後面追加元素
                2 insert(i,元素值)
                    在列表指定位置前插入元素
                3 extend(iterable)
                    把iterable中的元素依次添加到原列表
            2 刪
                1 pop()
                    參數不寫,預設是刪除最後一個元素
                    參數也可以指定索引號,來刪除
                2 remove
                    刪除指定的元素值
                3 del
                    切片或者單個刪除
                4 clear
                    清空元素
            3 改
                1 按照索引-下標修改
                    切片修改
                    單個索引號修改
            4 查
                1、單個索引號取值
                2、for迴圈遍歷

                01列表-增加元素小結
                    1 append是末尾追加新元素--最常用
                    2 insert是指定位置前插入新元素
                    3 extend是將iterable中元素依次添加到原列表
                02列表-刪除元素小結
                    1 pop
                        不帶參數,預設刪除列表最後一個元素,並且獲取到被刪除的最後一個元素
                        指定參數,刪除指定位置-索引號的元素,並且獲取到被刪除的指定位置的元素
                    2 remove
                        參數:元素值(不是位置)
                        作用:刪除指定元素值
                    3 del
                        1 參數:單個位置-索引號
                          寫法:del 列表(位置)
                          作用:刪除單個位置的元素
                        2、參數:切片
                          寫法:del 列表(切片)
                          作用:切片刪除多個位置的元素
                        3、參數:列表名
                           寫法:del 列表名
                           作用:刪除整個列表,回收記憶體空間(和清空clear是不同的)
                        4、參數:字典的key
                            寫法:del 字典名[key]
                            作用:刪除字典中指定key對應的鍵值對
                        綜上,del的作用
                        1、可以刪除單個位置的元素
                        2、可以切片刪除多個元素
                        3、可以刪除整個列表,回收記憶體空間
                        4、不僅是列表,也適用於字典
                    4 clear
                        參數:為空
                        寫法:li1.clear()
                        作用:清空列表的元素,變成空列表
                             清空-列表的記憶體空間沒有被回收(和del li1不一樣)
                03列表-修改元素小結
                    1 單個位置修改--單個元素修改
                        寫法:li3[1] = 'james'
                        作用:指定位置-索引號進行列表單個元素的修改

                    2、切片多個元素修改
                        1 2個元素改成1個元素
                            正確寫法:li3[1:3] = ['james']
                            錯誤寫法:li3[1:3] = 'james'   註意點

                        2 2個元素改成2個元素
                            寫法:li3[1:3] = ['james','kevin']

                        3 2個元素改成3個元素
                            寫法:li3[1:3] = ['james','kevin','lucy']
                04列表-查詢元素小結
                    1 單個查詢-單個取值-按照單個位置-索引號-下標
                    2 多個查詢-多個取值-按照切片
                    3 全部查詢-全部取值-for迴圈遍歷

            5、其他常見操作
                1 count() 計數
                    計算某個元素在列表出現的次數
                2 index() 查找
                    返回某個元素在列表中的位置-索引號-下標
                3 sort() 排序
                    把列表的元素進行排序,預設升序,列表本身修改了
                4 reverse()反轉
                    把列表的元素反轉,列表本身修改了

            6、列表在迴圈遍歷的過程中,不能刪除元素,因為涉及到元素的移動
               解決辦法:
               把要刪除的元素,添加到新的列表中,迴圈新列表,刪除老列表

            7、深淺拷貝和賦值
                1、= 賦值,兩個變數指向同一個記憶體地址,不同的變數只是同一個記憶體地址的不同別名
                2、淺拷貝,只拷貝第一層(第二層及以上還是指向同一個記憶體空間,沒有實現拷貝)
                    li1.copy()
                    li1[:]
                    檢驗是否是一個記憶體空間的辦法:看變數的id值
                3、深拷貝,不僅拷貝第一層,第二層及以上都拷貝
                    li1.deepcopy()
                擴展:在其他的編程語言(比如:java),叫做克隆,也分為深淺克隆

                淺拷貝和深拷貝的類比
                1、淺拷貝是第一層記憶體空間分開,第二層及以上記憶體空間是同一個
                         --第一層獨立,第二層及以上是一變都變
                          第一層就是家庭夫妻財務AA
                          第二層就是家庭夫妻設立的共同賬戶
                2、深拷貝是第一層記憶體空間分開,第二層及以上記憶體空間也分開--每層完全獨立
                          類比:家庭夫妻財務完全AA,沒有設立共同賬戶

            8、列表推導式
                寫法
                    [結果 for迴圈 if判斷]
                例子:
                    li7 = [1,2,3]
                    #需求:將列表中的奇數,變成其平方數
                    li8 = [i*i for i in li7 if i%2 == 1 ]
                    print(li8)  #[1, 9]

'''

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • <code> 標簽 解釋:保留輸入的格式空格等不變,原樣顯示在網頁上 例如: <pre> 通知 即日起不再提供公共設施 個店鋪需自行準備。 望周知~!! 2020/10/10 </pre> ...
  • <code> 標簽 解釋:要讓一段電腦代碼顯示在網頁中,那麼這段代碼需要用<code> 標簽包起來,不然他會被當作網頁的代碼被 運行。 例如: <code><img src="" alt=""></code> ...
  • 第一次接觸混合開發,然後碰到了很多H5+api,調用手機相冊,掃碼,保存圖片等。做技術的註定了要終生學習,但學無止境,我們不可能把所有的知識技能都學完了,學精通了再去工作,我們需要在工作中去提升自己,在工作紅去總結去成長。 我項目是用mui加H5+去開發的,所以在調用H5+的api時要等plusre ...
  • 在很多web項目中我們保存的圖片都是後臺的我們負責渲染到頁面上,但是前端也是可以截圖的,可是會有很多出人意料的bug,由於工作中遇到過所以就記錄下來吧。 前提:後臺傳一張二維碼的圖片以及個人頭像名稱性別然後在頁面展示,這很簡單,但是我們需要將二維碼個人頭像名稱性別合成一張圖片保存下來。 工具插件:h ...
  • 前言 在上一篇中,我們通過初步的認識,簡單瞭解 Vue 生命周期的八個階段,以及可以應用在之後的開發中,針對不同的階段的鉤子採取不同的操作,更好的實現我們的業務代碼,處理更加複雜的業務邏輯。 而在這一篇中,我們將通過配置vue的開發環境以及搭建項目,進一步的學習vue在開發中的使用方式。 對於開發v ...
  • 23種GoF設計模式概述 在前面,我們對 GoF 的 23 種設計模式進行了分類,這裡先對各個設計模式的功能進行簡要介紹,以便有個大概瞭解。後面的章節再進行詳細介紹。 創建型模式 關註於怎麼創建對象的創建型模式,他們將對象的創建與使用相互分離,對象的使用者無需關心如何創建對象,只知道怎麼使用就行,以 ...
  • 1 基礎概念 1.1. 什麼是事務 什麼是事務?舉個生活的例子 :你去小賣部買東西,“一手交錢,一手交貨“就是一個事務的例子,交錢和交貨必須全部成功,事務才算成功,任一個活動失敗,事務將撤銷所有已成功的活動。明白上述例子,再來看事務的定義 :事務可以看做是一次大的活動,它由不同的小活動組成,這些活動 ...
  • 本段源碼可以學習的地方: 1. 考慮到效率問題,可以通過上下文的機制,在屬性被訪問的時候臨時構建; 2. 可以重寫一些魔術方法,比如 __new__ 方法,在調用 object.__new__(cls) 前後進行屬性的一些小設置; 3. 在本庫中使用的重寫魔術方法,上下文這兩種基礎之上,我們可以想... ...
一周排行
    -Advertisement-
    Play Games
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...