Python之路【第二篇】:Python基礎

来源:https://www.cnblogs.com/hackerer/archive/2018/01/08/8244361.html
-Advertisement-
Play Games

Python基礎 對於Python,一切事物都是對象,對象基於類創建 所以,以下這些值都時對象:"zhurui"、22、['北京','上海','深圳'],並且是根據不同的類生成的對象。 一、基本數據類型 數字(int) 如:21、45、56 每一個整數都具備如下功能: 字元串(str) 1、name ...


Python基礎

對於Python,一切事物都是對象,對象基於類創建

所以,以下這些值都時對象:"zhurui"、22、['北京','上海','深圳'],並且是根據不同的類生成的對象。

 

一、基本數據類型

數字(int)

如:21、45、56

每一個整數都具備如下功能:

 

 1 - int
 2  將字元串轉換為數字
 3 例子:
 4 a = "123"
 5 print(type(a),a)
 6 輸出結果:
 7 >>> a = "123"
 8 >>> print(type(a),a)
 9 <class 'str'> 123
10 
11 b = int(a)
12 print(type(b),b)
13 
14 輸出結果:
15 >>> b = int(a)
16 >>> print(type(b),b)
17 <class 'int'> 123
18 
19 num = "0022"
20 v = int(num, base=16)
21 print(v)
22 
23 輸出結果:
24 >>> num = "0022"
25 >>> v = int(num, base=16)
26 >>> print(v)
27 34
28 
29 - bit_length
30  #當前數字的二進位,至少用n位表示
31 age = 22
32 v = age.bit_length()
33 print(v)
34 
35 輸出結果:
36 >>> age = 22
37 >>> v = age.bit_length()
38 >>> print(v)
39 5

字元串(str)

1、name.capitalize()   #首字母大寫

例子:

>>> test = "zhUrui"
>>> v = test.capitalize()
>>> print(v)
Zhurui

 

2、name.casefold()   #所有變小寫,casefold更牛逼,很多未知的對相應變小寫

例子:

>>> test = "zhUrui"
>>> v1 = test.casefold()
>>> print(v1)
zhurui
>>> v2 = test.lower()
>>> print(v2)
zhurui

 

3、name.center()  #設置寬度,並將內容居中 

   name.ljust()   #設置寬度,變數向左,其他部分用所定義的填充符 填充

   name.rjust()  #設置寬度,變數向右,其他部分用所定義的填充符 填充

      name.zfill()  #設置寬度,預設變數向右,其他部分用zfill方法特定的填充符"000" 填充

>>> test = "zhurui"
>>> v = test.center(20,"")
>>> print(v)
中中中中中中中zhurui中中中中中中中

解釋:
#  20   代指總長度
#   *    空白未知填充,一個字元,可有可無

輸出結果:
中中中中中中中zhurui中中中中中中中
##########################################
>>> test = "zhurui"
>>> v = test.ljust(20,"*") #ljust 變數靠左,其他部分用*填充
>>> print(v)
zhurui**************

##################################
>>> test = "zhurui"
>>> v = test.rjust(20,"*") #rjust 變數靠右,其他部分用*填充
>>> print(v)
**************zhurui
>>> test = "zhurui"
>>> v = test.zfill(20)  ##zfill只能用於000填充
>>> print(v)
00000000000000zhurui

 

 4、name.count()   #去字元串中尋找,尋找子序列的出現次數

>>> test = "Zhuruizhuruiru"
>>> v = test.count('ru')
>>> print(v)
3
>>> v = test.count('z')
>>> print(v)
1

#########################################
>>> test = "Zhuruizhuruiru"
>>> v = test.count('ru', 5, 6)
>>> print(v)
0

 

5、name.encode()  #將字元串編碼成bytes格式

6、name.decode()

 

7、name.endswith("ui")  #判斷字元串是否以ui結尾

   name.startswith('ui')  #判斷字元串是否以ui開始

>>> test = "zhurui"
>>> v = test.endswith('ui')
>>> print(v)
True
>>> v = test.startswith('ui')
>>> print(v)
False

 

 8、"Zhu\tRui".expandtabs(10)  #輸出‘Zhu          Rui’, 將\t轉換為多長的空格

>>> test = "Zhu\tRui"
>>> v = test.expandtabs(10)
>>> print(v)
Zhu       Rui

################################
test = "username\tpassword\temail\nzhurui\t123456\[email protected]\nzhurui\t123456\[email protected]\nzhurui\t123456\[email protected]"
v = test.expandtabs(20)
print(v)

輸出結果:

C:\Python35\python3.exe C:/Users/ZR/PycharmProjects/python全棧開發/day1/logging.py
username            password            email
zhurui              123456              24731701@qq.com
zhurui              123456              24731701@qq.com
zhurui              123456              [email protected]

 

9、name.find(A)  #從開始往後找,找到第一個之後,獲取其位置即索引,找不到返回-1

## > 或 >=
# 未找到 -1
>>> test = "williamwilliam" >>> v = test.find('am') >>> print(v) 5 >>> v = test.find('t') #找變數中的"t"字元, >>> print(v) -1 ##沒有找到,返回負一

 

10、name.index('a')  #找不到,報錯

>>> test = "williamwilliam"
>>> v = test.index('a')
>>> print(v)
5
>>> v = test.index('8')  ##找字元串中是否
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ValueError: substring not found

 

11、name.format()  #格式化,將一個字元串中的占位符替換為指定的值

>>> test = 'i am {name}, age {a}'
>>> print(test)
i am {name}, age {a}
>>> v = test.format(name='william',a=22)
>>> print(v)
i am william, age 22

 

>>> test = 'i am {0},age {1}'
>>> print(test)
i am {0},age {1}
>>> v = test.format('william', 22)
>>> print(v)
i am william,age 22

 

 12、name.format_map() #格式化, 傳入的值{"name":  'william',  "a":  22}

>>> test = 'i am {name}, age {a}'
>>> v1 = test.format(name='zhurui',a=22)
>>> v2 = test.format_map({"name":'zhurui', "a": 19})
>>> print(v1)
i am zhurui, age 22
>>> print(v2)
i am zhurui, age 19

 

13、name.isalnum() #字元串中是否只包含  字母和數字

>>> test = "234"
>>> v = test.isalnum()
>>> print(v)
True

 

14、name.isalpha() #是否是字母,漢字

>>> test = "asfdge242"
>>> v = test.isalpha()
>>> print(v)
False
>>> test = "威廉"
>>> v = test.isalpha()
>>> print(v)
True

 

15、判斷輸入的是否是數字

>>> test = "" # 1 , ②
>>> v1 = test.isdecimal   ##判斷十進位小數
>>> v2 = test.isdigit()
>>> v3 = test.isnumeric()  ##判斷漢語的數字,比如 "二"
>>> print(v1,v2,v3)
<built-in method isdecimal of str object at 0x00000201FE440AB0> False True

 

 16、name.isprintable() #判斷是否存在不可顯示的字元

\t  製表符
\n 換行
>>> test = "qepoetewt\tfdfde" >>> v = test.isprintable() >>> print(v) False >>> test = "qepoetewtfdfde" >>> v = test.isprintable() >>> print(v) True

 

 17、name.isspace() #判斷是否全部是空格

>>> test = ""
>>> v = test.isspace()
>>> print(v)
False
>>> test = " "
>>> v = test.isspace()
>>> print(v)
True

 

18、name.istitle() #判斷是否是標題,其中必須首字母大寫

>>> test = "Return True if all cased characters in S are uppercase"
>>> v1 = test.istitle()
>>> print(v1)
False
>>> v2 = test.title()  #將字元串首字母大寫
>>> print(v2)
Return True If All Cased Characters In S Are Uppercase
>>> v3= v2.istitle()
>>> print(v3)
True

 

19、***** name.join() #將字元串中的每一個元素按照指定分隔符進行拼接(五星重點參數)

>>> test = "出任CEO迎娶白富美"
>>> print(test)
出任CEO迎娶白富美
>>> v = '_'.join(test)
>>> print(v)
出_任_C_E_O_迎_娶_白_富_美
>>>

 

20、name.islower() #判斷是否全部是大小寫 和 轉換為大小寫

>>> test = "William"
>>> v1 =test.islower() #判斷是否全都是小寫
>>> v2 = test.lower()  #將變數轉換為小寫
>>> print(v1, v2)
False william
>>>

###################################

>>> test = "William"
>>> v1 =test.isupper() #判斷是否全都是大寫
>>> v2 = test.upper()  #將變數轉換為大寫
>>> print(v1, v2)
False WILLIAM

 

 21、移除指定字元串,優先最多匹配

>>> test = 'xa'
>>> v1 =test.isupper()
>>> v = test.lstrip("xa")
>>> print(v)

>>> v = test.rstrip("92exxxexxa")
>>> print(v)

>>> v = test.strip("xa")
>>> print(v)

###################################
# test.lstrip()
# test.rstrip()
# test.strip()
# 去除左右空白
# v = test.lstrip()
# v = test.rstrip()
# v = test.strip()
# print(v)
# print(test)
# 去除\t \n
# v = test.lstrip()
# v = test.rstrip()
# v = test.strip()
# print(v)

 

22、對應關係替換

>>> test = "aeiou"
>>> test1 = "12345"
>>> v = "asidufkasd;fiuadkf;adfkjalsdjf"
>>> m = str.maketrans("aeiou", "12345")
>>> new_v = v.translate(m)
>>> print(new_v)
1s3d5fk1sd;f351dkf;1dfkj1lsdjf

 

23、name.partition() #分割為三部分

>>> test = "testegerwerwegwewe"
>>> v = test.partition('s')
>>> print(v)
('te', 's', 'tegerwerwegwewe')
>>> v = test.rpartition('s')
>>> print(v)
('te', 's', 'tegerwerwegwewe')
>>>

 

24、name.split() #分格為指定個數

>>> test = "sagesgegessress"
>>> v = test.split('s',2)
>>> print(v)
['', 'age', 'gegessress']
>>>

 

25、分割, 只能根據,true, false:是否保留換行

>>> test = "fwerwerdf\frweqnndasfq\fnaqewrwe"
>>> v = test.splitlines(False)
>>> print(v)
['fwerwerdf', 'rweqnndasfq', 'naqewrwe']

 

26、以xxx開頭,以xx結尾

>>> test = "backend 1.2.3.4"
>>> v = test.startswith('a')
>>> print(v)
False
>>> test.endswith('a')
False

 

27、name.swapcase() #大小寫轉換

>>> test = "WiiLiAm"
>>> v = test.swapcase()
>>> print(v)
wIIlIaM

 

28、name.isidentifier() #字母,數字,下劃線  :標識符  def  class

>>> a = "def"
>>> v = a.isidentifier()
>>> print(v)
True

 

29、name.replace() #將指定字元串替換為指定字元串,替換功能相當於sed

>>> test = "williamwilliamwilliam"
>>> v = test.replace("am", "bbb")
>>> print(v)
willibbbwillibbbwillibbb
>>> v = test.replace("am", "bbb",2)
>>> print(v)
willibbbwillibbbwilliam
>>>

 字元串總結

################7個基本魔法#################
join    # '_'.join("asdfdfsdsf")
split
find
strip
upper
lower
replace(相當於sed替換功能)


################4個灰魔法#################
一、for迴圈
 格式:
 for 變數名 in  字元串:
      變數名
break
continue

例子:
test = "好看的妹子有種沖我來"
for item in test:
    print(item)
    break
輸出結果為:
    好

例子2:
test = "好看的妹子有種沖我來"
index = 0
while index < len(test):
    v = test[index]
    print(v)
    index += 1
print('============')
輸出結果為:
C:\Python35\python3.exe C:/Users/ZR/PycharmProjects/python全棧開發/day12/index1.py
好
看
的
妹
子
有
種
沖
我
來
============

例子3:(比較break跟continue的區別)
test = "好看的妹子有種沖我來"

for item in test:
     print(item)
     break
輸出結果為:
 好

for item in test:
     print(item)
     continue
輸出結果為:
C:\Python35\python3.exe C:/Users/ZR/PycharmProjects/python全棧開發/day12/index1.py
好
看
的
妹
子
有
種
沖
我
來

二、索引,下標,獲取字元串中的某一個字元
test = "好看的妹子有種沖我來"
v = test[3]
print(v)
輸出結果為:
妹

三、切片
v = test[0:1]  #標識大於等於0,小於1(0<= <1)
print(v)
輸出結果為:
好

四、獲取長度
Python3:  len獲取當前字元串中由幾個字元組成
v = len(test)
print(v)
輸出結果為:
10

註意:
len("asdf")
for迴圈
索引
切片
五、獲取連續或不連續的數字
Python2中直接創建在內容中
Python3中只有for迴圈時,才一個一個創建
例子:
r1 = range(10)
print(r1)
輸出結果為:
10
range(0, 10)
執行for迴圈時:
才會一個一個創建列印
r2 = range(1,10)
r3 = range(1,10,2)
幫助創建連續的數字,通過設置步長來指定不連續
v = range(0, 100, 5) #括弧中的5代表步長
for item in v:
    print(item)

 練習題:根據用戶輸入的值,輸出每一個字元以及當前字元所在的索引位置

將文字  對應的索引列印出來:
方法1:

test = input(">>>")
print(test)   # test = qwe   test[0]   test[1]
l = len(test) # l = 3
print(l)

r = range(0,l) # 0,3
for item in r:
print(item, test[item]) # 0 q,1 w,2 e

方法2:

test = input('>>>')
for item in range(0, len(test)):
    print(item, test[item])
##################### 1個深灰魔法 ######################
字元串一旦創建,不可修改
一旦修改或者拼接,都會造成重新生成字元串
name = "william"
age = "22"
    
info = name + age
print(info)

  

列表(list)

如:["william",'zhurui']、["ray","william"]

#################深灰魔法#####################

1、列表格式

# 中括弧括起來

# , 逗號分隔每個元素

# 列表中的元素可以是  數字,字元串,列表,布爾值.. 所有的都能放進去

# “集合”, 內部放置任何東西

 

2、列表中可以嵌套任何類型

# 列表中的元素可以是  數字,字元串,列表,布爾值.. 所有的都能放進去

# “集合”, 內部放置任何東西

 

3、索引取值

# list  # 類,列表
li = [1, 12, 9, "age", ["朱銳", ["19", 10], ""], "william", True]  # 通過list類創建的對象,li

>>> li = [1, 12, 9, "age", ["朱銳", ["19", 10], ""], "william", True]
>>> print(li[2])
9
>>> print(li[4][0])
朱銳

 

4、切片,切片結果也是列表

>>> li = [1, 12, 9, "age", ["朱銳", ["19", 10], ""], "william", True]
>>> print(li[3:-1])
['age', ['朱銳', ['19', 10], ''], 'william']

 

5、列表是可迭代的所以for迴圈、while迴圈都通用

>>> li = [1, 12, 9, "age", ["朱銳", ["19", 10], ""], "william", True]
>>> for item in li:
...   print(item)
...
1
12
9
age
['朱銳', ['19', 10], '']
william
True
>>>

 

####列表元素,可以被修改

6、通過索引的方式修改

>>> li = [1, 12, 9, "age", ["朱銳", ["19", 10], ""], "william", True]
>>> li[0] = "zhurui"
>>> print(li)
['zhurui', 12, 9, 'age', ['朱銳', ['19', 10], ''], 'william', True]
>>> li[1] = [11,22,44] #將原來索引1所對應記憶體中的12,賦值一個新的列表[11,22,44]
>>> print(li)
['zhurui', [11, 22, 44], 9, 'age', ['朱銳', ['19', 10], ''], 'william', True]
>>>

 

7、通過切片的方式修改列表中的元素

#修改中還有一個特殊的方法del
>>> li = [1, 12, 9, "age", ["朱銳", ["19", 10], ""], "william", True]
>>> del li[1]
>>> print(li)
[1, 9, 'age', ['朱銳', ['19', 10], ''], 'william', True]
>>>

#通過切片的方式刪除
>>> li = [1, 12, 9, "age", ["朱銳", ["19", 10], ""], "william", True]
>>> del li[2:6]  #2<=  <6
>>> print(li)
[1, 12, True]
>>>

#通過切片的方式修改
>>> li = [1, 12, 9, "age", ["朱銳", ["19", 10], ""], "william", True]
>>> li[1:3] = [120,90]
>>> print(li)
[1, 120, 90, 'age', ['朱銳', ['19', 10], ''], 'william', True]
>>>

 

8、in 操作

>>> li = [1, 12, 9, "age", ["朱銳", ["19", 10], "朱"], "william", True]
>>> v1 = "朱銳" in li
>>> print(v1)
False
>>> v2 = "age" in li
>>> print(v2)
True
>>> v3 = "william" in li
>>> print(v3)
True

####列表中的元素

9、操作

>>> li = [1, 12, 9, "age", ["朱銳", ["19", 10], ""], "william", True]
>>> li[4][1][0]
'19'

 

10、轉換

>>> s = 123
>>> a = "123"
>>> int(a)  #將字元串轉換為數字
123
>>> a = 123
>>> str(a)  #將數字轉換為字元串
'123'

##字元串轉換為列表
>>> li = list("asdfgeqrererdfgaf")  #字元串轉換為列表實質是內部使用了for迴圈
>>> print(li)
['a', 's', 'd', 'f', 'g', 'e', 'q', 'r', 'e', 'r', 'e', 'r', 'd', 'f', 'g', 'a', 'f']
>>>

>>> s = "erewsfsasdfe"
>>> new_li = list(s)
>>> print(new_li)
['e', 'r', 'e', 'w', 's', 'f', 's', 'a', 's', 'd', 'f', 'e']


##列表轉換為字元串,有兩種處理方法:
1、需要自己寫for迴圈一個一個處理:
>>> li = [12,14,146,"343","william"]
>>> r = str(li)
>>> print(r)
[12, 14, 146, '343', 'william']  #當直接將列表使用str轉換為字元串時,其他的都無變化,只是雙引號變為單引號
>>> s = ""  #定義一個空的字元串
>>> for i in li:  #迴圈列表
...   s += str(i)  #使用for迴圈將列表中的元素轉換為字元串與空字元串相加,得到新的變數s
...
>>> print(s)
1214146343william

2、直接使用字元串join方法:只僅僅適用於列表中的元素只有字元串
>>> li = ["4324","william"]
>>> v = "".join(li)
>>> print(v)
4324william

##補充:字元串創建後,不可修改

>>> v = "william"
>>> v = v.replace('w','am') #使用字元串的方法,將w替換為am
>>> print(v)
amilliam
>>> li = [11,232,434,45	   

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

-Advertisement-
Play Games
更多相關文章
  • Model-View-Controller(模型-視圖-控制器,MVC)模式將你的軟體組織並分解成三個截然不同的角色: Model 封裝了你的應用數據、應用流程和業務邏輯。 View 從 Model 獲取數據並格式化數據以進行顯示。 Controller 控製程序流程,接收輸入,並把它們傳遞給 Mo ...
  • AI(Artificial Intelligence)正在不斷的改變著各個行業的形態和人們的生活方式,圖像識別、語音識別、自然語言理解等 AI 技術正在自動駕駛、智能機器人、人臉識別、智能助理等領域中發揮著越來越重要的作用。 那麼當手繪視頻遇到 AI,有 AI 的手繪視頻領域,有 AI 的 UWP ...
  • 前言 在上一篇《【原創】打造基於Dapper的數據訪問層》中,Dapper在應付多表自由關聯、分組查詢、匿名查詢等應用場景時經常要手動寫SQL語句。看著代碼里滿屏的紅色SQL字元串,簡直頭大,於是便萌生重覆造ORM這個輪子的念頭。本ORM在API設計上最大程度地借鑒 EF 的寫法,支持鏈式查詢(點標 ...
  • 第一次用adb,一開始只是想試試看能不能解析出,沒有看網上的現有解析方式。 需要安卓機開啟usb 調試+電腦運行。打開跳一跳的界面 點擊程式 【開始】按鈕即可開始,別的按鈕都是調試用的 主要流程是用abd 截圖傳到電腦開始解析,用顏色計算出起點,然後通過起點計算出終點。然後用adb模擬按壓屏幕。 小 ...
  • 打開vs2017開發者命令提示符 切換至安裝下的指定目錄 執行下麵的命令就可以了 需要註意的是一定要用vs2017的開發人員命令提示符 別用cmd ...
  • 最近有幸閱讀了陳希章花了一年時間為國內開發者貢獻的《Office 365 開發入門指南》。 雖然早期接觸過SharePoint的開發,2007年之後就再也沒有接觸SharePoint的開發,這次閱讀這本書讓我重新認識了Office的系統開發技術,讓我意識到現在的Office 開發也是.NET Cor... ...
  • 1.下載mysql資料庫 鏈接https://dev.mysql.com/downloads/mysql/ 2.解壓到自己喜歡的文件夾下麵,我自己的建在D:\DataBase\mysql-5.7.20-winx64 3.配置環境變數: 4.然後在解壓目錄新建my-default.ini配置文件,配置 ...
  • cp命令的基本用法: cp 源文件 目標文件 如果目標文件不存在 就創建, 如果存在就覆蓋 實現一個cp命令其實就是讀寫文件的操作: 對於源文件: 把內容全部讀取到緩存中,用到的函數read 對於目標文件: 把緩存中的內容全部寫入到目標文件,用到的函數creat 1 /* 2 * Copyright ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...