ScoDocMM/misc/change_etudid.py

75 lines
2.2 KiB
Python
Raw Permalink Normal View History

2020-09-26 16:19:37 +02:00
#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""Change un etudid
Suite a de fausses manips, il arrive que l'on est des "doublons":
le même étudiant est enregistré sous deux "etudid" différents !
Normalement, l'utilisation d'imports basés sur le code NIP (Apogée)
évite le problème (qui ne se pose qu'en cas d'inscriptions manuelles
mal gérées).
Ce script permet de changer un etudid, typiquement pour associer à un
etudiant le code d'un autre étudiant (son doublon).
Ne traite que les inscriptions, les notes, absences, annotations, mais
évidemment pas les tables uniques (identité, adresse, admission).
Attention: script a lancer en tant que "www-data", avec ScoDoc arrete
et postgresql lance
2020-11-26 10:23:52 +01:00
Emmanuel Viennet, 2007-2020
2020-09-26 16:19:37 +02:00
"""
2020-11-26 10:23:52 +01:00
import pdb, os, sys, psycopg2
2020-09-26 16:19:37 +02:00
2020-11-26 10:23:52 +01:00
if len(sys.argv) != 4:
print "Usage: %s database orig_etudid dest_etudid" % sys.argv[0]
print " Fusionne l'étudiant orig dans l'étudiant dest."
print " L'identité, adresse et admission de dest restent inchangées."
print " Les inscriptions, notes, absences etc. d'orig sont associées à dest."
print " Après cette operation, orig_etudid peut être supprimé."
print "Exemple: change_etudid.py SCOGEII E1234 E87654"
sys.exit(1)
2020-09-26 16:19:37 +02:00
2020-11-26 10:23:52 +01:00
dbname = sys.argv[1]
OLD_ID = sys.argv[2] # etudid qui est en double (que l'on supprime)
NEW_ID = sys.argv[3] # etudid destination (celui d'origine)
2020-09-26 16:19:37 +02:00
2020-11-26 10:23:52 +01:00
DBCNXSTRING = "dbname=%s" % dbname
2020-09-26 16:19:37 +02:00
2020-11-26 10:23:52 +01:00
cnx = psycopg2.connect(DBCNXSTRING)
2020-09-26 16:19:37 +02:00
cursor = cnx.cursor()
req = "update %s set etudid=%%(new_etudid)s where etudid=%%(old_etudid)s"
2020-11-26 10:23:52 +01:00
args = {"old_etudid": OLD_ID, "new_etudid": NEW_ID}
tables = (
"absences",
"absences_notifications",
"billet_absence",
"scolog",
"etud_annotations",
"entreprise_contact",
"notes_formsemestre_inscription",
"notes_moduleimpl_inscription",
"notes_notes",
"notes_notes_log",
"scolar_events",
"scolar_formsemestre_validation",
"scolar_autorisation_inscription",
"notes_appreciations",
"itemsuivi",
"group_membership",
# nouvelles absences
#'abs_absences',
#'abs_presences',
#'abs_justifs',
)
2020-09-26 16:19:37 +02:00
for table in tables:
cursor.execute(req % table, args)
2020-11-26 10:23:52 +01:00
print "table %s: %s" % (table, cursor.statusmessage)
2020-09-26 16:19:37 +02:00
cnx.commit()