主頁 > 軟體設計 > python串列練習題

python串列練習題

2020-09-12 17:24:42 軟體設計

===================

python串列練習題

===================

一、創建串列

1.創建一個串列,命名為names,往里面添加陳賢賢、大財神、飛魚、WuYing、阿陽和Black元素,

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
print(names)

結果[‘陳賢賢’, ‘大財神’, ‘飛魚’, ‘WuYing’, ‘阿陽’, ‘Black’]

2.串列文字的添加

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
print('我建的學習群有', len(names), '個學生在微信群里面')
print('我建的學習群有' + str(len(names)) + '個學生在微信群里面')

for item in names:
    print(names)
print('我在渡劫也加入了微信群')

names.append('我在渡劫')
print('現在我的微信群是', names)

結果:

我建的學習群有 6 個學生在微信群里面 #6的前后都有空格存在
我建的學習群有6個學生在微信群里面 # 6個前后沒有空格存在
陳賢賢
大財神
飛魚
WuYing
阿陽
Black
我在渡劫也加入了微信群
現在我的微信群是 [‘陳賢賢’, ‘大財神’, ‘飛魚’, ‘WuYing’, ‘阿陽’, ‘Black’, ‘我在渡劫’]

二、在串列中插入元素

1.往names串列中的最后一個元素Black前面插入一個張四歲,

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
names.insert(-1, "張四歲")
print(names)

結果[‘陳賢賢’, ‘大財神’, ‘飛魚’, ‘WuYing’, ‘阿陽’, ‘張四歲’, ‘Black’]

2.往names串列中最前面的元素陳賢賢前面插入張四歲

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
names.insert(0, '張四歲')
print(names)

結果[‘張四歲’, ‘陳賢賢’, ‘大財神’, ‘飛魚’, ‘WuYing’, ‘阿陽’, ‘Black’]

3.往names串列中中間部位的元素飛魚前面插入張四歲

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
names.insert(2, '張四歲')
print(names)

結果[‘陳賢賢’, ‘大財神’, ‘張四歲’, ‘飛魚’, ‘WuYing’, ‘阿陽’, ‘Black’]

4.往names串列中大財神后面插入一個子串列[“老男孩”,“老女孩”],

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
names.insert(2, ["老男孩", "老女孩"])
print(names)

結果:[‘陳賢賢’, ‘大財神’, [‘老男孩’, ‘老女孩’], ‘飛魚’, ‘WuYing’, ‘阿陽’, ‘Black’]

三、改變串列中的某一個元素的名稱

1.把names串列中WuYing的名字改成中文,

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
names[names.index("WuYing")] = "吳瑩"
print(names)

結果:[‘陳賢賢’, ‘大財神’, ‘飛魚’, ‘吳瑩’, ‘阿陽’, ‘Black’]

2.把names串列中飛魚的名字改成數字666

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
names[names.index('飛魚')] = 666
print(names)

結果:[‘陳賢賢’, ‘大財神’, 666, ‘WuYing’, ‘阿陽’, ‘Black’]

3.修改特定元素

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
names[3] = "吳瑩"
print(names)

結果:[‘陳賢賢’, ‘大財神’, ‘飛魚’, ‘吳瑩’, ‘阿陽’, ‘Black’]

4.批量修改元素名

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
names[0:2] = 'abcd'  # 將索引0-2替換為abcd,切片之后迭代處理
print(names)

結果:[‘a’, ‘b’, ‘c’, ‘d’, ‘飛魚’, ‘WuYing’, ‘阿陽’, ‘Black’]

四、確定串列中元素的位置(索引值)

1.回傳names串列中阿陽的索引值(下標),

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
print(names.index("阿陽"))

結果:4

五、兩個串列的合并

1.創建新串列numbers,依次包含1,2,3,4,2,5,6,2等數,并把新串列合并到names串列中,

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
numbers = [1, 2, 3, 4, 2, 5, 6, 2]
names.extend(numbers)  # extend()方法表示合并
print(names)

結果:[‘陳賢賢’, ‘大財神’, ‘飛魚’, ‘WuYing’, ‘阿陽’, ‘Black’, 1, 2, 3, 4, 2, 5, 6, 2]

六、取出串列中指定元素

1.取出names串列中索引4-7的元素,

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black", 1, 2, 3, 4, 2, 5, 6, 2]
print(names[4:8])

結果:[‘阿陽’, ‘Black’, 1, 2]

2.取出names串列中索引2-10的元素,步長為2,

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black", 1, 2, 3, 4, 2, 5, 6, 2]
print(names[2:11:2])  # 串列切片“顧頭不顧尾”,步長表示在指定范圍間隔取值

#結果:[‘飛魚’, ‘阿陽’, 1, 3, 2]

3.取出names串列中最后3個元素,

names = ['陳賢賢', '大財神', ['老男孩', '老女孩'], '飛魚', '吳瑩', '阿陽', '張四歲', 'Black', 1, 2, 3, 4, 2, 5, 6, 2]
print(names[-3:])  # [-3:]表示取值范圍為從串列的倒數第三個到末尾

結果:[5, 6, 2]

七、列印特定索引值和元素

1.回圈names串列,列印每個元素的索引值和元素,

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]

方法1

for i in names:
    print(names.index(i), i)

方法2 enumerate()列舉

for index, i in enumerate(names):
    print(index, i)

結果:

0 陳賢賢
1 大財神
2 飛魚
3 WuYing
4 阿陽
5 Black

2.回圈names串列,列印每個元素的索引值和元素,當索引值為偶數時,把對應的元素改成-1,

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black", 1, 2, 3, 4, 2, 5, 6, 2]
for index, i in enumerate(names):
    if index % 2 == 0:
        names[index] = -1
        print(index, i)
print(names)

結果:[-1, ‘大財神’, -1, ‘WuYing’, -1, ‘Black’, -1, 2, -1, 4, -1, 5, -1, 2]

3.names串列里有3個2,請回傳第二個2的索引值,不要人肉,要動態找,

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black", 1, 2, 3, 4, 2, 5, 6, 2]

方法1 回圈

count = 0
for index, i in enumerate(names):
    # print(index,i)
    if i == 2:
        count += 1
        while count == 2:
            print(index)
            break
    else:
        continue

方法2

print(names.index(2, names.index(2)+1))

結果:10

4.現有商品串列如下:

products = [["iphone", 6888], ["MacPro", 14800], ["小米6", 2499], ["Coffee", 31], ["Book", 60], ["Nike", 699]]

需列印出以下格式:

------ 商品串列 ------
0 iphone 6888
1 MacPro 14800
2 小米6 2499
3 Coffee 31
4 Book 60
5 Nike 699

products = [["iphone", 6888], ["MacPro", 14800], ["小米6", 2499], ["Coffee", 31], ["Book", 60], ["Nike", 699]]
print("--------- 商品串列 --------")
for index, i in enumerate(products):
    print("%s %s %s" % (index, i[0], i[1]))

結果:

--------- 商品串列 --------
0 iphone 6888
1 MacPro 14800
2 小米6 2499
3 Coffee 31
4 Book 60
5 Nike 699

5.根據products串列寫一個回圈,不斷詢問用戶想買什么,用戶選擇一個商品編號,就把對應的商品添加到購物車里,最終用戶輸入q退出時,列印購買的商品串列,

products = [["iphone", 6888], ["MacPro", 14800], ["小米6", 2499], ["Coffee", 31], ["Book", 60], ["Nike", 699]]
shop_car = []  # 用戶購物車
shop_cost = 0  # 用戶花費的金額
exit_log = False  # 標志位,默認設為False,退出
while not exit_log:
    print("------ 商品串列 ------")
    for index, i in enumerate(products):
        print("%s   %s  %s" % (index, i[0], i[1]))
    user_choice = input("\n輸入你想購買的產品序號(按“q”退出):")
    if user_choice.isdigit():
        # 判斷用戶輸入的是否是數字
        user_choice = int(user_choice)  # 強制轉換為數字
        if user_choice >=0 and user_choice < len(products):
            # 判斷用戶購買的商品是否在商品串列中
            shop_car.append(products[user_choice])  # 加入購物車
            shop_cost += products[user_choice][1]  # 計算費用
            print("\n %s 已經加入你的購物車\n"%products[user_choice])
        else:
            print("抱歉,此商品不存在\n")
    elif user_choice == "q":
      # 用戶選擇退出
        if len(shop_car) > 0:
            # 判斷用戶是否購買了商品
            print("\n------ 你的購物車 ------")
            for index, i in enumerate(shop_car):
                # index和i為臨時變數,與前一個for回圈里index和i作用的串列不同,故可重用
                print("%s  %s" % (i[0], i[1]))
            print("\n你此次購物的花費合計是:%s元\n" % shop_cost)
            exit_log = True # 退出購物
        else:
            exit_log = True # 未購買商品,不列印購物車商品,直接退出
    else:
        # 輸入不合法
        exit_log = True

6.列印串列本身

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
print(names)

結果:[‘陳賢賢’, ‘大財神’, ‘飛魚’, ‘WuYing’, ‘阿陽’, ‘Black’]

7.依順序列印串列中所有元素

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]

方法一

print(names[0])
print(names[1])
print(names[2])
print(names[3])
print(names[4])

方法二

for i in names:
    print(i)

結果:[‘陳賢賢’, ‘大財神’, ‘飛魚’, ‘WuYing’, ‘阿陽’, ‘Black’]

8.調取一個串列元素的方法

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
print(names[3])

結果:WuYing

八、統計串列中元素的個數

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
print(len(names))

結果:6

九、增加串列中元素的方法:append方法

score = []
print(score)
score.append(80)
print(score)

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
names.append(1705)
names.append('HZH')
print(names)

print(names.append('HZH'))  # 無回傳值,names.append

結果:

[]
[80]
[‘陳賢賢’, ‘大財神’, ‘飛魚’, ‘WuYing’, ‘阿陽’, ‘Black’, 1705, ‘HZH’]
None

十、串列轉換成字串

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
a = "、".join(names)
print(a)

結果:陳賢賢、大財神、飛魚、WuYing、阿陽、Black

十一、洗掉元素

1.按照元素洗掉

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
names.remove('飛魚')
print(names)

結果:[‘陳賢賢’, ‘大財神’, ‘WuYing’, ‘阿陽’, ‘Black’]

2.按照索引洗掉

names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
names = names.pop()  # 不寫索引就洗掉最后一個之外所有其他的
print(names)
‘’‘

結果:Black


names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
names = names.pop(2)  # 保留第3個,洗掉所有其他的
print(names)

結果:飛魚


names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
names = names.clear()  # 清除串列
print(names)

結果:None


names = ["陳賢賢", "大財神", "飛魚", "WuYing", "阿陽", "Black"]
for i in range(len(names)):  # 一個一個地洗掉
    print(i)
    del names[0]
    print(names)

結果:

0
[‘大財神’, ‘飛魚’, ‘WuYing’, ‘阿陽’, ‘Black’]
1
[‘飛魚’, ‘WuYing’, ‘阿陽’, ‘Black’]
2
[‘WuYing’, ‘阿陽’, ‘Black’]
3
[‘阿陽’, ‘Black’]
4
[‘Black’]
5
[]

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/15717.html

標籤:其他

上一篇:python爬蟲之網路請求

下一篇:爬蟲實戰系列(八):淘寶店鋪各品牌手機售賣資訊爬取及可視化

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more