2025年8月28日 星期四

只要點兩下就能產出彰化縣Cloud School 學生帳號密碼匯入彰化縣EIP系統學生帳號密碼的CSV

系列文章:
1.只要點兩下就能產出彰化縣Cloud School 學生帳號密碼匯入彰化縣EIP系統學生帳號密碼的CSV
1.https://skjhcreator.blogspot.com/2025/08/cloud-school-eipcsv.html
2.只要點兩下就能利用彰化縣EIP系統學生帳號CSV產出建立Google Classroom 學生總表
2.https://skjhcreator.blogspot.com/2025/08/eipcsvgoogle-classroom.html 
3.
只要點兩下就能利用彰化縣EIP系統學生帳號CSV產出指定學生名單的Google Classroom學生帳號總表
3.https://skjhcreator.blogspot.com/2025/09/eipcsvgoogle-classroom.html

        彰化縣數位學習師生單一帳號系統(EIP=Enterprise Information Portal)於2025年7月7日正式啟用。由於EIP、Cloud School 會進行資料同步,但密碼卻不會一致。身為一個教師,讓學生記多組帳號密碼,那是一件愚蠢的事。換句話說,資訊組長需要手動進行,讓EIP、Cloud School密碼一致。但問題是Cloud School匯出的表為all.xlsx,彰化縣EIP系統學生帳號密碼匯入的格式是CSV。更嚴重的是兩者的欄位格式完全不同、排序也不同。如果一次下載全校學生的資料,需要手動修改的地方就會很多。雖然一年只要做一次,但是想到每年都要做,就讓人覺得心煩。有沒有辦法,讓整件事變得簡單。例如,下載兩個系統的資料後,只要滑鼠點兩下,就產出彰化縣EIP系統學生帳號密碼匯入的CSV。然後一次匯入,就結束。
        以下為問題描述,都是直接用Excel開啟:
1.
Cloud School 學生資料下載方式:

下載的學生資料檔名為all.xlsx,其格式如下:
學生名單從70101開始往下排。
2.
EIP學生帳號下載方式:
下載的學生資料檔名為學校代碼_學生資料_日期時間.CSV,其格式如下:
學生名單從90101開始往下排。學生帳號如上圖的第7個,只知道是4開頭的數字,但不知道是04開頭的,還是4開頭的。若要確認,還要用記事本去開啟CSV,才能夠確認。若是直接用Excel開啟後,直接複製密碼,貼上另一個檔案。儲存之後,學生帳號如上圖的第7個,格式就會被存成4開頭的數字。還要人工一個個檢查。

下載檔案解壓密碼:demo1234
Here is the website where you can download the program and find instructions:
Download。Extraction Password: demo1234
使用教學(Instructional videos):

以下是開發過程與原始碼 (Development process and code):
安裝套件openpyxl
指令(command):
pip install openpyxl
 
程式名稱(Program name):pyCloudSchool_pwd2EIP_pwd.py
程式內容(Code):
import csv
import os
from openpyxl import load_workbook

# 取得目前的工作目錄
current_directory = os.getcwd()
# 取得目前的工作目錄內input
current_directory_input = current_directory+"\\input\\"
#  取得工作目錄input內所有檔案名稱
current_directory_input_files = os.listdir(current_directory_input)

# 以副檔名來判斷設定相對應的檔案
for i in current_directory_input_files:
    TempFileName,TempFileExtension = os.path.splitext(i)
    if TempFileExtension == ".csv":
        TempCSVFile = i
    elif TempFileExtension == ".xlsx":
        TempXLSXFile = i
    else:
        TempTXT = i

# 設定CSVList為一個 list
CSVList = []
# 開啟 CSV 檔案
with open(current_directory_input+TempCSVFile, mode='r', encoding='utf-8') as file:
    # 建立 CSV 讀取器
    reader = csv.reader(file)
    # 逐行讀取 CSV 檔案內容
    for row in reader:
        CSVList.append(row)

# 設定 ExcelList 為一個list
ExcelList = []
# 載入 Excel 文件
workbook = load_workbook(current_directory_input+TempXLSXFile)
# 取得所有工作表名稱
sheet_names = workbook.sheetnames
# 選擇特定工作表
sheet = workbook[sheet_names[0]]
# 讀取工作表內容
for row in sheet.iter_rows(values_only=True):
    ExcelList.append([str(row[0])+str(row[1]).zfill(2)+str(row[2]).zfill(2),row[7]])
# 關閉工作簿
workbook.close()
# CSVListTitle 取得 CSVList[0]
CSVListTitle = CSVList[0]
# 刪除CSVList[0]
CSVList.pop(0)
# 對CSVList 進行排序
CSVList.sort(key=lambda x: x[0])
# ExcelListTitle 取得 CSVList[0]
ExcelListTitle = ExcelList[0]
# 刪除ExcelList[0]
ExcelList.pop(0)
# 對ExcelList 進行排序
ExcelList.sort(key=lambda x: x[0])
# 複製一份ExcelList
CopyExcelList = ExcelList[:]

ResultList = []
ResultList.append(CSVListTitle)

# 當兩者檔案學生名單長度不一致
if len(ExcelList)-len(CSVList) != 0:
    for i in ExcelList:
        for j in CSVList:
            if i[0] == j[0]:
                ResultList.append([str(j[0]),str(j[1]),str(i[1])])
                CopyExcelList.remove(i)
               
    # 印出不一致的學生名單
    #print("印出不一致的學生名單:")                
    #print(CopyExcelList)
    with open(current_directory+"\\CloudSchool_pwd2EIP_pwd_Exception.txt", "w",encoding="utf-8") as file:
        file.write("印出不一致的學生名單:\n")
        for i in CopyExcelList:
            file.write(str(i)+"\n")
    print("CloudSchool_pwd2EIP_pwd_Exception.txt 檔案已成功寫入!")
else: # 當兩者檔案學生名單長度一致
    for i in range(len(CSVList)):
        if ExcelList[i][0] == CSVList[i][0]:
            ResultList.append([str(CSVList[i][0]),str(CSVList[i][1]),str(ExcelList[i][1])])

with open(current_directory+"\\CloudSchool_pwd2EIP_pwd.csv", mode="w", newline="", encoding="utf-8") as file:
    writer = csv.writer(file)
    writer.writerows(ResultList)

print("CloudSchool_pwd2EIP_pwd.csv檔案已成功寫入!")




資料來源:



沒有留言:

張貼留言

只要點兩下兩次,就能依照設定拆分指定PDF頁數並合併成設定好的一個PDF

        最近遇到一個問題,想要對四個不同的PDF,分別擷取1~2頁、3~4頁、5~6頁、7~8頁,合併成一個總共8頁的PDF。那該怎麼寫程式來處理這件事呢?那如果是用線上拆分PDF網頁與線上合併PDF網頁,該怎麼做呢?則是需要將四個不同PDF分別上傳到拆分網頁後再 一頁一...