這篇文章主要介紹了python使用jt400.jar包的方法,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
成都創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價比扎囊網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式扎囊網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋扎囊地區(qū)。費用合理售后完善,10年實體公司更值得信賴。代碼如下
jt400helper.py
#coding=utf-8 import jpype import os class JT400Helper(object): def __init__(self, server,username,pwd): jvmpath=r"C:\Program Files\Java\jre1.8.0_60\bin\server\jvm.dll" jarpath=r'd:\temp\jt400.jar' jvmArg = "-Djava.class.path=%s" % jarpath jpype.startJVM(jvmpath,jvmArg) #jt400 AS400=jpype.JClass('com.ibm.as400.access.AS400') CommandCall=jpype.JClass('com.ibm.as400.access.CommandCall') ProgramCall=jpype.JClass('com.ibm.as400.access.ProgramCall') SpooledFileList=jpype.JClass('com.ibm.as400.access.SpooledFileList') AS400Text=jpype.JClass('com.ibm.as400.access.AS400Text') AS400JDBCDriver=jpype.JClass('com.ibm.as400.access.AS400JDBCDriver') #java Connection=jpype.JClass('java.sql.Connection') DatabaseMetaData=jpype.JClass('java.sql.DatabaseMetaData') Statement=jpype.JClass('java.sql.Statement') self.ResultSet=jpype.JClass('java.sql.ResultSet') self.server,self.username,self.pwd = server,username,pwd self.RJobLog=jpype.JClass('com.ibm.as400.resource.RJobLog') self.AS400FTP=jpype.JClass('com.ibm.as400.access.AS400FTP') self.IFSFile=jpype.JClass('com.ibm.as400.access.IFSFile') self.ObjectDescription=jpype.JClass('com.ibm.as400.access.ObjectDescription') self.ProgramParameter=jpype.JClass('com.ibm.as400.access.ProgramParameter') self.DriverManager=jpype.JClass('java.sql.DriverManager') self.DriverManager.registerDriver(AS400JDBCDriver()) self.system=AS400(server,username,pwd) self.cc=CommandCall(self.system) self.outqueue = SpooledFileList(self.system) self.pc = ProgramCall(self.system) def ShowIfs(self,ifspath): ifs=self.IFSFile(self.system,ifspath) print 'exists : ',ifs.exists() print 'isDirectory : ',ifs.isDirectory() print 'isFile : ',ifs.isFile() fs=ifs.listFiles() if len(fs)>0: for f in fs: print f.name def ShowObj2(self,lib,obj): od = self.ObjectDescription(system,lib,obj,"FILE") print od.CHANGE_DATE_AND_TIME def ShowObj(self,lib,obj,tmplib): cmdstr = "DSPOBJD OBJ(%s/%s) OBJTYPE(*PGM) OUTPUT(*OUTFILE) OUTFILE(%s/OBJD)" % (lib,obj,tmplib) msg = self.GetCmdMsg(cmdstr) if msg == "": cmdstr = "SELECT ODLBNM, ODOBNM, ODOBTP, ODOBAT,ODOBSZ , ODOBTX, ODLDAT, ODLTIM, ODOBSY, ODCRTU, ODJRST, ODJRNM, ODJRLB, ODJRIM, ODJREN,ODJRCN, ODJRDT, ODJRTI FROM %s.objd" % tmplib self.GetSQLResult(cmdstr) def SaveFieldDef(self,flib,file,tmplib,ofile): cmdstr = "DSPFFD FILE(%s/%s) OUTPUT(*OUTFILE) OUTFILE(%s/FIELDDEF)" % (flib,file,tmplib) msg = self.GetCmdMsg(cmdstr) if msg == "": cmdstr = "SELECT WHFLDI, WHFTXT, WHFLDT, WHFLDD, WHFLDP,WHFLDB, WHFOBO FROM %s.FIELDDEF WHERE WHFLDI <> ' ' ORDER BY WHFOBO" % tmplib self.GetSQLResult(cmdstr,ofile) def SaveJobLog(self,jobstr,ofile): msg = self.GetJobLog(jobstr) with open(ofile,'w') as f: f.write(msg) def GetJobLog(self,jobstr): jobarr = jobstr.split('/') jobnum,jobuser,jobname=jobarr[0],jobarr[1],jobarr[2] return self.GetJobLogByNum(jobnum,jobuser,jobname) def GetJobLogByNum(self,jobnum,jobuser,jobname): joblog=self.RJobLog(self.system,jobname,jobuser,jobnum) joblog.open() joblog.waitForComplete() num=joblog.getListLength() msgs = [] for i in range(0,num): qmsg=joblog.resourceAt(i) msgs.append(qmsg.getAttributeValue("MESSAGE_TEXT")) msg = '\n'.join(msgs) return msg def GetSQLResult(self,cmdstr,ofile=""): connection = self.DriverManager.getConnection("jdbc:as400://" + self.server, self.username, self.pwd) dmd = connection.getMetaData() select = connection.createStatement(self.ResultSet.TYPE_SCROLL_SENSITIVE,self.ResultSet.CONCUR_UPDATABLE) print cmdstr rs = select.executeQuery(cmdstr) strs = "" cols = rs.getMetaData().getColumnCount() while (rs.next()): rowstrs = [] for i in range(1,cols+1): value = rs.getString(i) if ' ' in value: value = '"%s"' % value rowstrs.append(rs.getString(i)) strs+=','.join(rowstrs)+'\n' connection.close(); if ofile <> "": with open(ofile,'w') as f: f.write(strs) else: print strs def CallProgram(self,plib,pgm,paras): #WRKACTJOB SBS(QUSRWRK) JOB(QZRCSRVS) - dump not work #paras=["Y","12345"," "] pgmparas=[] for para in paras: pgmparas.append(ProgramParameter(para)) print str(pgmparas.getInputData()) self.pc.setProgram("/QSYS.LIB/%s.LIB/%s.PGM" % (plib,pgm),pgmparas) successfully = self.pc.run() msg = '' job = pc.getJob() print pc.toString() print job.toString() if successfully <> True: ml=self.pc.getMessageList() for m in ml: msg += m.getText() +'\n' print msg self.system.disconnectAllServices() return msg def GetCmdMsg(self,cmdstr): msg = '' print cmdstr successfully = self.cc.run(cmdstr) if successfully <> True: ml=self.cc.getMessageList() for m in ml: msg += m.getText() +'\n' print msg return msg def CheckObjExists(self,lib,file,type="*FILE"): str = "CHKOBJ OBJ(%s/%s) OBJTYPE(%s)" % (lib,file,type) return self.GetCmdMsg(str) def DeleteObj(self,lib,file): str = "DLTF FILE(%s/%s)" % (lib,file) return self.GetCmdMsg(str) def FileToIfs(self,lib,file,mem,ifspath): # don't use RMVBLANK(*TRAILING) ,will cause numeric field contains blank characters error when put ifs to file str = "CPYTOIMPF FROMFILE(%s/%s %s) TOSTMF('%s') MBROPT(*REPLACE) STMFCCSID(*STMF) RCDDLM(*CRLF) DTAFMT(*DLM) STRDLM(*NONE)" % (lib,file,mem,ifspath) print lib,file,mem,"->",ifspath return self.GetCmdMsg(str) def IfsToFile(self,ifspath,lib,file,mem): str = "CPYFRMIMPF FROMSTMF('%s') TOFILE(%s/%s %s) MBROPT(*REPLACE) RCDDLM(*CRLF) STRDLM(*NONE) FLDDLM(',') ERRRCDOPT(*REPLACE) RPLNULLVAL(*FLDDFT)" % (ifspath,lib,file,mem) print ifspath,"->",lib,file,mem return self.GetCmdMsg(str) def FileToPc(self,lib,file,mem,ofile): tmpifs = "QDLS/TEMP/%s.CSV" % mem self.FileToIfs(lib,file,mem,tmpifs) self.FtpGetIfsFile(tmpifs,ofile) def PcToFile(self,ifile,lib,file,mem): tmpifs = "QDLS/TEMP/%s.CSV" % mem self.FtpPutIfsFile(ifile,tmpifs) self.IfsToFile(tmpifs,lib,file,mem) def FtpGetIfsFile(self,ifspath,ofile): ftp=self.AS400FTP(self.system) successfully = ftp.get(ifspath,ofile) print ifspath,"->",ofile return successfully def FtpGetText(self,lib,srcf,mem,dest=r"d:\temp"): ftp=self.AS400FTP(self.system) target="/QSYS.LIB/%s.LIB/%s.FILE/%s.MBR" % (lib,srcf,mem) if os.path.isdir(dest): dest=os.path.join(dest,mem+".txt") print target,"->",dest successfully = ftp.get(target,dest) return successfully def FtpGetSavf(self,lib,savf,dest=r"d:\temp"): ftp=self.AS400FTP(self.system) target="/QSYS.LIB/%s.LIB/%s.SAVF" % (lib,savf) # QUOTE SITE NAMEFMT 0 QGPL/QCLSRC.TEST # QUOTE SITE NAMEFMT 1 /QSYS.lib/Libname.lib/Fname.file/Mname.mbr ftp.issueCommand("quote site namefmt 1") if os.path.isdir(dest): dest=os.path.join(dest,savf+".SAVF") # can not get it if not set data transfer type ftp.setDataTransferType(1) successfully = ftp.get(target,dest) return successfully def FtpPutIfsFile(self,ifile,ifspath): ftp=self.AS400FTP(self.system) successfully = ftp.put(ifile,ifspath) print ifile,"->",ifspath return successfully def FtpPutText(self,ifile,lib,srcf,mem): ftp=self.AS400FTP(self.system) dest="/QSYS.LIB/%s.LIB/%s.FILE/%s.MBR" % (lib,srcf,mem) successfully = ftp.put(ifile,dest) print ifile,"->",lib,srcf,mem return successfully def GetOutQList(self,outqlib,outq): print "OutQueue : %s/%s" % (outqlib,outq) self.outqueue.setQueueFilter("/QSYS.LIB/%s.LIB/%s.OUTQ" % (outqlib,outq)) self.outqueue.setUserFilter("*ALL") self.outqueue.openSynchronously() enums=self.outqueue.getObjects() i = 1 info = "" while (enums.hasMoreElements()): splf=enums.nextElement() if(splf<>None): strs=[] strs.append("System :%s , File : %s , File Number : %s , Progarm :%s , Date : %s" % (splf.getStringAttribute(271),splf.getStringAttribute(104),splf.getIntegerAttribute(105).toString(),splf.getStringAttribute(272),splf.getStringAttribute(34))) strs.append("Number/User/Job : %s/%s/%s" % (splf.getStringAttribute(60),splf.getStringAttribute(62),splf.getStringAttribute(59))) strs.append("File Pages: %s , Print quality : %s , Printer device type : %s , Page size length : %d " % (splf.getIntegerAttribute(111).toString(),splf.getStringAttribute(48),splf.getStringAttribute(90),splf.getFloatAttribute(78).intValue())) info += '\n'.join(strs)+'\n' i+=1 self.system.disconnectAllServices() print "total spool files : ",i print info def GetSpoolFile(self,sflib,sffile,sfname,sfjobnum,fnum,dest): if self.CheckObjExists(sflib,sffile)<>"": # IGCDTA parameter is for DBCS file self.GetCmdMsg("CRTPF FILE(%s/%s) RCDLEN(160) IGCDTA(*YES)" % (sflib,sffile)) str = "CPYSPLF FILE(%s) TOFILE(%s/%s) JOB(%s) SPLNBR(%d)" % (sfname,sflib,sffile,sfjobnum,fnum) msg = self.GetCmdMsg(str) if msg == "": self.FtpGetText(sflib,sffile,sffile,dest) print "download successfully!" def PutMsg(self,qlib,qname,msg): qstr = "/QSYS.LIB/%s.LIB/%s.DTAQ" % (qlib,qname) dataqueue=self.DataQueue(self.system,qstr) dataqueue.write(msg) def GetMsg(self,qlib,qname): qstr = "/QSYS.LIB/%s.LIB/%s.DTAQ" % (qlib,qname) dataqueue=self.DataQueue(self.system,qstr) dqdata = dataqueue.read() dqdatastr = 'No data' if dqdata <> None: dqdatastr = dqdata.getString() print dqdatastr return dqdatastr if __name__ == '__main__': pass
感謝你能夠認真閱讀完這篇文章,希望小編分享的“python使用jt400.jar包的方法”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司,關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道,更多相關(guān)知識等著你來學習!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、網(wǎng)站設(shè)計器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
新聞標題:python使用jt400.jar包的方法-創(chuàng)新互聯(lián)
瀏覽地址:http://aaarwkj.com/article18/cocsdp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供軟件開發(fā)、營銷型網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計公司、品牌網(wǎng)站建設(shè)、關(guān)鍵詞優(yōu)化、服務(wù)器托管
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)