日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python学习之路day02

發布時間:2024/7/19 python 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python学习之路day02 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一、.pyc是什么?

1. Python是一門解釋型語言?

我初學Python時,聽到的關于Python的第一句話就是,Python是一門解釋性語言,我就這樣一直相信下去,直到發現了*.pyc文件的存在。如果是解釋型語言,那么生成的*.pyc文件是什么呢?c應該是compiled的縮寫才對啊!

為了防止其他學習Python的人也被這句話誤解,那么我們就在文中來澄清下這個問題,并且把一些基礎概念給理清。

2. 解釋型語言和編譯型語言?

計算機是不能夠識別高級語言的,所以當我們運行一個高級語言程序的時候,就需要一個“翻譯機”來從事把高級語言轉變成計算機能讀懂的機器語言的過程。這個過程分成兩類,第一種是編譯,第二種是解釋。

編譯型語言在程序執行之前,先會通過編譯器對程序執行一個編譯的過程,把程序轉變成機器語言。運行時就不需要翻譯,而直接執行就可以了。最典型的例子就是C語言。

解釋型語言就沒有這個編譯的過程,而是在程序運行的時候,通過解釋器對程序逐行作出解釋,然后直接運行,最典型的例子是Ruby。

通過以上的例子,我們可以來總結一下解釋型語言和編譯型語言的優缺點,因為編譯型語言在程序運行之前就已經對程序做出了“翻譯”,所以在運行時就少掉了“翻譯”的過程,所以效率比較高。但是我們也不能一概而論,一些解釋型語言也可以通過解釋器的優化來在對程序做出翻譯時對整個程序做出優化,從而在效率上超過編譯型語言。

此外,隨著Java等基于虛擬機的語言的興起,我們又不能把語言純粹地分成解釋型和編譯型這兩種。

用Java來舉例,Java首先是通過編譯器編譯成字節碼文件,然后在運行時通過解釋器給解釋成機器文件。所以我們說Java是一種先編譯后解釋的語言。

3. Python到底是什么?

其實Python和Java/C#一樣,也是一門基于虛擬機的語言,我們先來從表面上簡單地了解一下Python程序的運行過程吧。

當我們在命令行中輸入python hello.py時,其實是激活了Python的“解釋器”,告訴“解釋器”:你要開始工作了。可是在“解釋”之前,其實執行的第一項工作和Java一樣,是編譯。

熟悉Java的同學可以想一下我們在命令行中如何執行一個Java的程序:

javac hello.java

java hello

只是我們在用Eclipse之類的IDE時,將這兩部給融合成了一部而已。其實Python也一樣,當我們執行python hello.py時,他也一樣執行了這么一個過程,所以我們應該這樣來描述Python,Python是一門先編譯后解釋的語言。

4. 簡述Python的運行過程

在說這個問題之前,我們先來說兩個概念,PyCodeObject和pyc文件。

我們在硬盤上看到的pyc自然不必多說,而其實PyCodeObject則是Python編譯器真正編譯成的結果。我們先簡單知道就可以了,繼續向下看。

當python程序運行時,編譯的結果則是保存在位于內存中的PyCodeObject中,當Python程序運行結束時,Python解釋器則將PyCodeObject寫回到pyc文件中。

當python程序第二次運行時,首先程序會在硬盤中尋找pyc文件,如果找到,則直接載入,否則就重復上面的過程。

所以我們應該這樣來定位PyCodeObject和pyc文件,我們說pyc文件其實是PyCodeObject的一種持久化保存方式。

?二、數據類型

1、數字

2 是一個整數的例子。
長整數 不過是大一些的整數。
3.23和52.3E-4是浮點數的例子。E標記表示10的冪。在這里,52.3E-4表示52.3 * 10-4。
(-5+4j)和(2.3-4.6j)是復數的例子,其中-5,4為實數,j為虛數,數學中表示復數是什么?。

int(整型)

在32位機器上,整數的位數為32位,取值范圍為-2**31~2**31-1,即-2147483648~2147483647
  在64位系統上,整數的位數為64位,取值范圍為-2**63~2**63-1,即-9223372036854775808~9223372036854775807 long(長整型)
  跟C語言不同,Python的長整數沒有指定位寬,即:Python沒有限制長整數數值的大小,但實際上由于機器內存有限,我們使用的長整數數值不可能無限大。
  注意,自從Python2.2起,如果整數發生溢出,Python會自動將整數數據轉換為長整數,所以如今在長整數數據后面不加字母L也不會導致嚴重后果了。
float(浮點型)
  浮點數用來處理實數,即帶有小數的數字。類似于C語言中的double類型,占8個字節(64位),其中52位表示底,11位表示指數,剩下的一位表示符號。
complex(復數)
  復數由實數部分和虛數部分組成,一般形式為x+yj,其中的x是復數的實數部分,y是復數的虛數部分,這里的x和y都是實數。 注:Python中存在小數字池:-5 ~ 257 2、布爾值 真或假 1 或 0 3、字符串 "hello world" 萬惡的字符串拼接: python中的字符串在C語言中體現為是一個字符數組,每次創建字符串時候需要在內存中開辟一塊連續的空,并且一旦需要修改字符串的話,就需要再次開辟空間,萬惡的+號每出現一次就會在內從中重新開辟一塊空間。 三、數據運算 算數運算:

比較運算:

賦值運算:

邏輯運算:

成員運算:

身份運算:

位運算:

運算符優先級:

更多內容:猛擊這里

四、encode與decode

?

五、列表的操作;[]

names=["!@zhangyang","45guyun","chenronghua","xiangpeng","Niexiaomin","Xuliangchen"]

print(names[0],(names[2]))
print(names[1:3])
print(names[-1])
names.append("yanbing")
names.insert(2,"wuxiansen")
names[-1]="Niexiaomin"
# names.remove("niexiaomin") #移除值
# del names[0] #刪除指定的值
# names.pop() #刪除最后一個值
print(names.count("niexiaomin"))
# print(names[3:-1])
# print(names[0::3])
# names2=[1,3,5,7,9]
# names.extend(names2) #列表的擴展
# names.reverse()
names.sort() #排序,sort中不支持單數字與字符類型排序
names_copy=names.copy()
print(names_copy)
print(names.index("Niexiaomin"))
print(names)
六、元組的操作:() import copy
names=["!@zhangyang","45guyun","chenronghua",["alex","jack"],"xiangpeng","Niexiaomin","Xuliangchen"]

print(names[1:10:2])
for i in names:
print(i)

name1=copy.deepcopy(names) #深copy,導入copy
name2=copy.copy(names) #淺copy,導入copy
#name1=copy.deepcopy(names)
names2=names.copy()
names[2]="XIEDI"
names[3][0]="ALEXANDER"
print(names)
print(names2)
七、程序練習?

請閉眼寫出以下程序。

程序:購物車程序

需求:

  • 啟動程序后,讓用戶輸入工資,然后打印商品列表
  • 允許用戶根據商品編號購買商品
  • 用戶選擇商品后,檢測余額是否夠,夠就直接扣款,不夠就提醒?
  • 可隨時退出,退出時,打印已購買商品和余額
  • 備注:index 打印下標;enumerate 打印下標
  • 八、字符串操作
    name.capitalize() 首字母大寫 name.casefold() 大寫全部變小寫 name.center(50,"-") 輸出 '---------------------Alex Li----------------------' name.count('lex') 統計 lex出現次數 name.encode() 將字符串編碼成bytes格式 name.endswith("Li") 判斷字符串是否以 Li結尾"Alex\tLi".expandtabs(10) 輸出'Alex Li', 將\t轉換成多長的空格 name.find('A') 查找A,找到返回其索引, 找不到返回-1

    九、字典操作info = { 'stu1101': "TengLan Wu",
    'stu1102': "LongZe Luola",
    'stu1103': "XiaoZe Maliya",
    }

    info['stu1104']="蒼井空" #增
    del info["stu1101"] #刪除
    info["stu1101"]="武藤蘭" #修改
    c=info.get("stu1103") #查
    print(c)
    print("stu1102" in info)
    info.pop("stu1104")
    info.popitem()

    print(info.values())
    print(info.keys())
    print(info.setdefault("stu1101","wuteng lan"))
    #print(info)

    for key in info:
    print(key,info[key])
    for k,v in info.items():
    print(k,v)
    十、三級菜單作業



    轉載于:https://www.cnblogs.com/0818and0119/p/9919113.html

    總結

    以上是生活随笔為你收集整理的python学习之路day02的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。