zoukankan      html  css  js  c++  java
  • 某某系统从外部基础库读取数据

    前提要开通访问策略和1521端口

    import schedule
    import time
    import datetime
    import csv
    import shutil
    from django.core.management.base import BaseCommand, CommandError
    from d3.models import Student, Xueji, TempXueji
    from userapp.models import Jg
    import cx_Oracle as db
    import os
    from django.db.models import F, Func
    from django.db.models.functions import Length, Upper
    from django.db.models import Q, Count, Max, Min, Sum, Avg
    
    os.environ['NLS_LANG'] = 'SIMPLIFIED CHINESE_CHINA.UTF8'
    
    
    def queryServerdb(sql):
        username = "xxxxx"
        passwd = "xxxxxx"
        host = "xxxxxx"
        port = "1521"
        sid = "xxxxxx"
        dsn = db.makedsn(host, port, service_name=sid)
        con = db.connect(user=username, password=passwd, dsn=dsn)
        cur = con.cursor()
        cur.execute(sql)
        result = cur.fetchall()
        cur.close()
        con.close()
        return (result)
    
    
    def queryLocaldb(sql):
        username = "lxg"
        passwd = "lxg"
        host = "127.0.0.1"
        port = "1521"
        sid = "XE"
        dsn = db.makedsn(host, port, service_name=sid)
        con = db.connect(user=username, password=passwd, dsn=dsn)
        cur = con.cursor()
        cur.execute(sql)
        result = cur.fetchall()
        cur.close()
        con.close()
        return (result)
    
    #取得原始的学籍信息(读取oracle库)
    def job_02_TempXueji():
        print('====begin==job_02_TempXueji==')
        sql = "select " 
              "xs_jbxx_id,sfzjlxm,sfzjh,xm,xxsszgjyxzdm," 
              "sheng,shi,xian,xxbsm,xxmc," 
              "jyjd_mc,xjnjdm_mc,jdztm_mc,sfzx_mc,sfby_mc," 
              "gxsj,grbsm from qzk_cjxs.ZXX_CJXS_BDXX"
        rows = queryServerdb(sql)
        TempXueji.objects.all().delete()
    
        tempXueji_list = []
        for row in rows:
            # try:
            #     obj = TempXueji.objects.get(xs_jbxx_id=row[0], gxsj=row[15])
            # except TempXueji.DoesNotExist:
            #     TempXueji.objects.filter(xs_jbxx_id=row[0]).delete()
            if row[13] == '':
                status = '在校生'
            elif row[14] == '':
                status = '初中毕业'
            else:
                status = '无学籍'
    
            obj = TempXueji(
                xs_jbxx_id=row[0],
                sfzjlxm=row[1],
                sfzjh=row[2],
                xm=row[3],
                xxsszgjyxzdm=row[4],
                sheng=row[5],
                shi=row[6],
                xian=row[7],
                xxbsm=row[8],
                xxmc=row[9],
                jyjd_mc=row[10],
                xjnjdm_mc=row[11],
                jdztm_mc=row[12],
                sfzx_mc=row[13],
                sfby_mc=row[14],
                gxsj=row[15],
                grbsm=row[16],
                status=status
            )
            tempXueji_list.append(obj)
    
        TempXueji.objects.bulk_create(tempXueji_list)
        print('====end==job_02_TempXueji==')
        print(str(TempXueji.objects.all().count()))
    import schedule
    import time
    import datetime
    import csv
    import shutil
    from django.core.management.base import BaseCommand, CommandError
    from d3.models import Student, Xueji, TempXueji
    from userapp.models import Jg
    import cx_Oracle as db
    import os
    from django.db.models import F, Func
    from django.db.models.functions import Length, Upper
    from django.db.models import Q, Count, Max, Min, Sum, Avg

    os.environ['NLS_LANG'] = 'SIMPLIFIED CHINESE_CHINA.UTF8'


    class Command(BaseCommand):
    help = 'working in command!'

    def handle(self, *args, **options):
    schedule.every().day.at("20:00").do(job_00)
    schedule.every().day.at("20:20").do(job_01)
    schedule.every().day.at("06:00").do(job_02_TempXueji)
    schedule.every().day.at("06:40").do(job_03_final)
    # schedule.every(2).seconds.do(job_02_TempXueji)
    # schedule.every(2).seconds.do(job_04_final())
    # schedule.every(2).seconds.do(job_00)
    # schedule.every(2).seconds.do(job_01)
    while True:
    schedule.run_pending()
    time.sleep(10)


    # 共享学生信息-导出csv
    def job_00():
    stuquery = Student.objects.all()
    with open('/home/sftp/sftpuser/students.csv', 'w') as csvfile:
    writer = csv.writer(csvfile, quotechar='"', quoting=csv.QUOTE_ALL)
    columns = ["数据年份", "应届往届",
    "机构id", "身份证", "姓名", "性别", "残疾类别 ", "残疾等级",
    "初核状态", "不安置原因", "安置方式"]

    rows = ([
    my_row.year, my_row.year_type,
    my_row.jg_id, my_row.sfz, my_row.name, my_row.get_gender_display(), my_row.get_dis_type_display(), my_row.get_dis_grade_display(),
    my_row.ifchuhe, my_row.noanzhi_type, my_row.anzhi_fangshi, ]
    for my_row in stuquery)

    writer.writerow(columns)
    for row in rows:
    writer.writerow(row)

    print("job_00working...")


    # 共享机构信息-导出csv
    def job_01():
    jgquery = Jg.objects.all()
    with open('/home/sftp/sftpuser/jg.csv', 'w') as csvfile:
    writer = csv.writer(csvfile, quotechar='"', quoting=csv.QUOTE_ALL)
    columns = ["机构id", "全称", "简称", "层级", "上级", "是否初核"]

    rows = ([
    my_row.p_code, my_row.full_name,
    my_row.short_name, my_row.level, my_row.parent_code, my_row.ifchuhe]
    for my_row in jgquery)

    writer.writerow(columns)
    for row in rows:
    writer.writerow(row)

    print("job_01working...")


    def queryServerdb(sql):
    username = "cjxs"
    passwd = "Tgds_901"
    host = "172.18.35.200"
    port = "1521"
    sid = "jcqzdb"
    dsn = db.makedsn(host, port, service_name=sid)
    con = db.connect(user=username, password=passwd, dsn=dsn)
    cur = con.cursor()
    cur.execute(sql)
    result = cur.fetchall()
    cur.close()
    con.close()
    return (result)


    def queryLocaldb(sql):
    username = "lxg"
    passwd = "lxg"
    host = "127.0.0.1"
    port = "1521"
    sid = "XE"
    dsn = db.makedsn(host, port, service_name=sid)
    con = db.connect(user=username, password=passwd, dsn=dsn)
    cur = con.cursor()
    cur.execute(sql)
    result = cur.fetchall()
    cur.close()
    con.close()
    return (result)

    #取得原始的学籍信息(读取oracle库)
    def job_02_TempXueji():
    print('====begin==job_02_TempXueji==')
    sql = "select "
    "xs_jbxx_id,sfzjlxm,sfzjh,xm,xxsszgjyxzdm,"
    "sheng,shi,xian,xxbsm,xxmc,"
    "jyjd_mc,xjnjdm_mc,jdztm_mc,sfzx_mc,sfby_mc,"
    "gxsj,grbsm from qzk_cjxs.ZXX_CJXS_BDXX"
    rows = queryServerdb(sql)
    TempXueji.objects.all().delete()

    tempXueji_list = []
    for row in rows:
    # try:
    # obj = TempXueji.objects.get(xs_jbxx_id=row[0], gxsj=row[15])
    # except TempXueji.DoesNotExist:
    # TempXueji.objects.filter(xs_jbxx_id=row[0]).delete()
    if row[13] == '':
    status = '在校生'
    elif row[14] == '':
    status = '初中毕业'
    else:
    status = '无学籍'

    obj = TempXueji(
    xs_jbxx_id=row[0],
    sfzjlxm=row[1],
    sfzjh=row[2],
    xm=row[3],
    xxsszgjyxzdm=row[4],
    sheng=row[5],
    shi=row[6],
    xian=row[7],
    xxbsm=row[8],
    xxmc=row[9],
    jyjd_mc=row[10],
    xjnjdm_mc=row[11],
    jdztm_mc=row[12],
    sfzx_mc=row[13],
    sfby_mc=row[14],
    gxsj=row[15],
    grbsm=row[16],
    status=status
    )
    tempXueji_list.append(obj)

    TempXueji.objects.bulk_create(tempXueji_list)
    print('====end==job_02_TempXueji==')
    print(str(TempXueji.objects.all().count()))
  • 相关阅读:
    别闹了,这些都不是数字化转型
    对不起,“下一代ERP”仍旧是现在的ERP
    这世界真小
    SAP S4HANA 2020 Fully-Activated Appliance 虚拟机版分享
    花费巨资参加SAP培训真的有用吗?
    剑指 Offer 07. 重建二叉树
    剑指 Offer 06. 从尾到头打印链表
    剑指 Offer 05. 替换空格
    剑指 Offer 04.二维数组中的查找
    剑指 Offer 03. 数组中重复的数字
  • 原文地址:https://www.cnblogs.com/lxgbky/p/14955416.html
Copyright © 2011-2022 走看看