欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python 處理表格進(jìn)行成績(jī)排序的操作代碼

 更新時(shí)間:2021年07月26日 10:59:29   作者:hhh_Moon_hhh  
這篇文章主要介紹了Python 處理表格進(jìn)行成績(jī)排序,也就是說將學(xué)生從按照學(xué)號(hào)排序變?yōu)榘凑粘煽?jī)從高到低進(jìn)行排序,具體實(shí)現(xiàn)代碼跟隨小編一起看看吧

一、需求分析

我們首先有一個(gè)成績(jī)表單,但是學(xué)生的成績(jī)是按照學(xué)號(hào)進(jìn)行排序的,現(xiàn)在,我們希望清晰明了的知道每一個(gè)學(xué)生的名次,并且需要將學(xué)生按照成績(jī)的高低重新進(jìn)行排序。

也就是說,我們將學(xué)生從按照學(xué)號(hào)排序轉(zhuǎn)變?yōu)榘凑粘煽?jī)從高到低進(jìn)行排序。

二、代碼呈現(xiàn)

這個(gè)需求其實(shí)比較簡(jiǎn)單,于是,我們直接呈現(xiàn)代碼,主要問題是Excel表格的讀寫操作,這個(gè)解決以后就十分簡(jiǎn)單了。

Excel讀:xlrd模塊
Excel寫:xlwt模塊

代碼以及解釋如下:

import xlwt
import xlrd
# 導(dǎo)入模塊

wb = xlwt.Workbook()  
# 創(chuàng)建 excel 表格
xls_0 = xlrd.open_workbook("四年級(jí)1.xls")
# 讀取表格文件

for i in range(4, 8, 1):
    # 讀取不同的表單
    new_sheet = xls_0.sheet_by_index(i)
    sh = wb.add_sheet(f'{new_sheet.name}.xls')  # 創(chuàng)建一個(gè) 表單

    # 設(shè)置空列表進(jìn)行數(shù)據(jù)的存儲(chǔ)
    id_list = []
    name_list = []
    score_list = []

    # 讀取表格的數(shù)據(jù)
    for o in range(3):  # 3 列
        for t in range(20):  # 20 行
            # 獲取學(xué)號(hào)、姓名、成績(jī)等信息
            id_list.append(new_sheet.cell(t + 3, 3 * o).value)
            name_list.append(new_sheet.cell(t + 3, 3 * o + 1).value)
            score_list.append(new_sheet.cell(t + 3, 3 * o + 2).value)
    # 獲取數(shù)據(jù)

    # 進(jìn)行一定的預(yù)處理,去除不存在的人
    # 意思是說:有些位置是空的,這些位置需要去除掉
    for number in range(len(id_list)):
        # 由于進(jìn)行的是刪除操作,所以可能會(huì)出現(xiàn)下標(biāo)越界的情況,為了防止這種情況的出現(xiàn),我們進(jìn)行異常處理
        try:
            if name_list[number] == '' or score_list[number] == '' or score_list[number] == '請(qǐng)假':
                # 這個(gè)實(shí)際上是去除空值
                id_list.pop(number)
                name_list.pop(number)
                score_list.pop(number)
        except:
            continue
    # 去除不存在的人

    # 進(jìn)行排序的操作
    for h in range(len(id_list)):
        # len(id_list) 次循環(huán)
        for s in range(len(id_list) - 1):
            # 這里是進(jìn)行 len(id_list) - 1 次循環(huán)
            try:
                if score_list[s] >= score_list[s + 1]:
                    pass
                else:
                    score_list[s], score_list[s + 1] = score_list[s + 1], score_list[s]
                    name_list[s], name_list[s + 1] = name_list[s + 1], name_list[s]
                    id_list[s], id_list[s + 1] = id_list[s + 1], id_list[s]
            except:
                continue
    # 冒泡排序

    # 將數(shù)據(jù)寫入文件
    position = 0
    
    for h in range(len(id_list)):
        # 寫入文件
        sh.write(position, 0, id_list[h])
        sh.write(position, 1, name_list[h])
        sh.write(position, 2, score_list[h])
        position += 1
    # 寫入文件中去

# 保存文件

wb.save(f'四年級(jí)1-五至八班-分?jǐn)?shù)排序.xls')  
# 保存

在這里,我們使用了冒泡排序,當(dāng)然,如果想要運(yùn)行的更快一些,可以考慮希爾排序,堆排序,快速排序等排序方式,但是要注意,學(xué)號(hào)、姓名、分?jǐn)?shù)一定要同時(shí)進(jìn)行排序,就是說這三個(gè)量應(yīng)該捆綁在一起移動(dòng),而移動(dòng)的原則就是分?jǐn)?shù)高低。

三、成果展示

圖片1、

在這里插入圖片描述

圖片2、

在這里插入圖片描述
圖片3、

在這里插入圖片描述

圖片4、

在這里插入圖片描述

到此這篇關(guān)于Python 處理表格進(jìn)行成績(jī)排序的操作代碼的文章就介紹到這了,更多相關(guān)Python成績(jī)排序內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python爬蟲獲取圖片并下載保存至本地的實(shí)例

    Python爬蟲獲取圖片并下載保存至本地的實(shí)例

    今天小編就為大家分享一篇Python爬蟲獲取圖片并下載保存至本地的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧
    2018-06-06
  • python如何通過psutil獲取服務(wù)器cpu、內(nèi)存、磁盤使用率

    python如何通過psutil獲取服務(wù)器cpu、內(nèi)存、磁盤使用率

    這篇文章主要介紹了python通過psutil獲取服務(wù)器cpu,內(nèi)存,磁盤使用率,使用psutil,可以很方便地監(jiān)控系統(tǒng)的運(yùn)行狀況,診斷問題和優(yōu)化性能,需要的朋友可以參考下
    2023-04-04
  • 用Python實(shí)現(xiàn)2024年春晚劉謙魔術(shù)

    用Python實(shí)現(xiàn)2024年春晚劉謙魔術(shù)

    昨晚春晚上劉謙的兩個(gè)魔術(shù)表演都非常精彩,忍不住用編程去模擬一下這個(gè)過程,所以本文給大家用Python實(shí)現(xiàn)2024年春晚劉謙魔術(shù),文中通過代碼示例給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2024-02-02
  • Python通過psd-tools解析PSD文件的實(shí)現(xiàn)

    Python通過psd-tools解析PSD文件的實(shí)現(xiàn)

    本文主要介紹了Python通過psd-tools解析PSD文件的實(shí)現(xiàn),主要包括如何獲取PSD文件的基本信息、遍歷圖層、提取圖層詳細(xì)信息、保存和創(chuàng)建PSD文件,感興趣的可以了解一下
    2023-12-12
  • 深入理解numpy中argmax的具體使用

    深入理解numpy中argmax的具體使用

    本文主要介紹了深入理解numpy中argmax的具體使用,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • python中strip(),lstrip(),rstrip()函數(shù)的使用講解

    python中strip(),lstrip(),rstrip()函數(shù)的使用講解

    這篇文章主要介紹了python中strip(),lstrip(),rstrip()函數(shù)的使用講解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • python?密碼驗(yàn)證(滑塊驗(yàn)證)

    python?密碼驗(yàn)證(滑塊驗(yàn)證)

    滑塊密碼在很多登錄界面都可以看到,本文主要介紹了python?密碼驗(yàn)證(滑塊驗(yàn)證),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Python confluent kafka客戶端配置kerberos認(rèn)證流程詳解

    Python confluent kafka客戶端配置kerberos認(rèn)證流程詳解

    這篇文章主要介紹了Python confluent kafka客戶端配置kerberos認(rèn)證流程詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-10-10
  • 使用PyInstaller將Pygame庫(kù)編寫的小游戲程序打包為exe文件及出現(xiàn)問題解決方法

    使用PyInstaller將Pygame庫(kù)編寫的小游戲程序打包為exe文件及出現(xiàn)問題解決方法

    這篇文章主要介紹了使用PyInstaller將Pygame庫(kù)編寫的小游戲程序打包為exe文件的方法,給大家介紹了通過Pyinstaller打包Pygame庫(kù)寫的小游戲程序出現(xiàn)的問題及解決方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-09-09
  • python下載的庫(kù)包存放路徑

    python下載的庫(kù)包存放路徑

    在本篇文章里小編給大家整理的是一篇關(guān)于python下載的庫(kù)包存放路徑,需要的朋友們可以參考學(xué)習(xí)下。
    2020-07-07

最新評(píng)論