弹出File Browser窗口

 PRIVATE FUNCTION cxrt020_open_file()
DEFINE l_dir LIKE type_t.chr500
DEFINE r_success LIKE type_t.num5
#
LET r_success = FALSE
CALL cl_client_browse_file() RETURNING l_dir
IF NOT cl_null(l_dir) THEN
CALL cxrt020_ins_excel(l_dir) RETURNING r_success
END IF
RETURN r_success END FUNCTION

######按路径,把xls的数据按格式顺序ins到数据表,注意xls的文件名不能有中文或特殊符号,最好全英文文件名;

 PRIVATE FUNCTION cxrt020_ins_excel(p_excelname)
DEFINE p_excelname LIKE type_t.chr1000 #excel档名
DEFINE r_success LIKE type_t.num5
DEFINE l_excelname STRING #excel档名
DEFINE l_count LIKE type_t.num10
DEFINE li_i LIKE type_t.num10
DEFINE li_j LIKE type_t.num10
DEFINE xlapp,iRes,iRow LIKE type_t.num5
DEFINE l_xrsguc RECORD LIKE xrsguc_t.*
DEFINE l_today LIKE type_t.dat
DEFINE l_n LIKE type_t.num5 WHENEVER ERROR CONTINUE
LET r_success = TRUE LET l_today= cl_get_current()
LET l_count = LENGTH(p_excelname CLIPPED)
#转换路径分隔符
FOR li_i = TO l_count
IF p_excelname[li_i,li_i] ="/" THEN
LET l_excelname = l_excelname CLIPPED,'\\'
ELSE
LET l_excelname = l_excelname CLIPPED,p_excelname[li_i,li_i]
END IF
END FOR CALL ui.interface.frontCall('WinCOM','CreateInstance',
['Excel.Application'],[xlApp])
IF xlApp <> - THEN
CALL ui.interface.frontCall('WinCOM','CallMethod',
[xlApp,'WorkBooks.Open',l_excelname],[iRes])
IF iRes <> - THEN
CALL ui.interface.frontCall('WinCOM','GetProperty',
[xlApp,'ActiveSheet.UsedRange.Rows.Count'],[iRow])
IF iRow > THEN
FOR li_i = TO iRow
INITIALIZE l_xrsguc.* TO NULL
LET l_xrsguc.xrsgucent = g_enterprise
LET l_xrsguc.xrsgucsite = g_site
CALL ui.interface.frontCall('WinCOM','GetProperty',[xlApp,'ActiveSheet.Cells('||li_i||',1).Value'],[l_xrsguc.xrsgucdocno])
CALL ui.interface.frontCall('WinCOM','GetProperty',[xlApp,'ActiveSheet.Cells('||li_i||',2).Value'],[l_xrsguc.xrsguc001])
CALL ui.interface.frontCall('WinCOM','GetProperty',[xlApp,'ActiveSheet.Cells('||li_i||',3).Value'],[l_xrsguc.xrsguc002])
CALL ui.interface.frontCall('WinCOM','GetProperty',[xlApp,'ActiveSheet.Cells('||li_i||',4).Value'],[l_xrsguc.xrsguc003])
CALL ui.interface.frontCall('WinCOM','GetProperty',[xlApp,'ActiveSheet.Cells('||li_i||',5).Value'],[l_xrsguc.xrsguc004])
CALL ui.interface.frontCall('WinCOM','GetProperty',[xlApp,'ActiveSheet.Cells('||li_i||',6).Value'],[l_xrsguc.xrsguc005])
CALL ui.interface.frontCall('WinCOM','GetProperty',[xlApp,'ActiveSheet.Cells('||li_i||',7).Value'],[l_xrsguc.xrsguc006])
CALL ui.interface.frontCall('WinCOM','GetProperty',[xlApp,'ActiveSheet.Cells('||li_i||',8).Value'],[l_xrsguc.xrsguc007])
CALL ui.interface.frontCall('WinCOM','GetProperty',[xlApp,'ActiveSheet.Cells('||li_i||',9).Value'],[l_xrsguc.xrsguc008])
CALL ui.interface.frontCall('WinCOM','GetProperty',[xlApp,'ActiveSheet.Cells('||li_i||',10).Value'],[l_xrsguc.xrsguc009])
CALL ui.interface.frontCall('WinCOM','GetProperty',[xlApp,'ActiveSheet.Cells('||li_i||',11).Value'],[l_xrsguc.xrsguc010])
CALL ui.interface.frontCall('WinCOM','GetProperty',[xlApp,'ActiveSheet.Cells('||li_i||',12).Value'],[l_xrsguc.xrsguc011])
CALL ui.interface.frontCall('WinCOM','GetProperty',[xlApp,'ActiveSheet.Cells('||li_i||',13).Value'],[l_xrsguc.xrsguc012])
CALL ui.interface.frontCall('WinCOM','GetProperty',[xlApp,'ActiveSheet.Cells('||li_i||',14).Value'],[l_xrsguc.xrsguc013])
#
INSERT INTO xrsguc_t VALUES l_xrsguc.*
IF SQLCA.sqlcode THEN
INITIALIZE g_errparam TO NULL
LET g_errparam.code = SQLCA.sqlcode
LET g_errparam.extend = 'INSERT INTO xrsguc_t'
LET g_errparam.popup = FALSE
CALL cl_err()
LET r_success = FALSE
EXIT FOR
END IF
END FOR
END IF
ELSE
INITIALIZE g_errparam TO NULL
LET g_errparam.code = 'axc-00387'
LET g_errparam.extend = '' #NO FILE
LET g_errparam.popup = TRUE
CALL cl_err()
LET r_success = FALSE
END IF
ELSE
INITIALIZE g_errparam TO NULL
LET g_errparam.code = 'axc-00387'
LET g_errparam.extend = '' #NO EXCEL
LET g_errparam.popup = TRUE
CALL cl_err()
LET r_success = FALSE
END IF CALL ui.interface.frontCall('WinCOM','CallMethod',[xlApp,'Quit'],[iRes])
CALL ui.interface.frontCall('WinCOM','ReleaseInstance',[xlApp],[iRes]) RETURN r_success END FUNCTION

最新文章

  1. IOS 开发中 Whose view is not in the window hierarchy 错误的解决办法
  2. [整理]SSRS error:rsReportNotReady
  3. 主机无法访问虚拟机上的elasticsearch服务器
  4. Django文档——Model中的ForeignKey,ManyToManyField与OneToOneField
  5. MyBatis学习总结2
  6. .Net 调式案例—实验4 高CPU(High CPU)回顾
  7. Java学习笔记(2):jdk的配置
  8. Action重定向总结
  9. 关于在App_Code文件夹自定义类中Session无法使用
  10. 宿主机跟Vmware中的linux使用host-only,bridge 方式通信
  11. vmware虚拟机和网络中的桥接和NAT
  12. ThreadLocal及InheritableThreadLocal的原理剖析
  13. mssql for xml path使用
  14. php-编译模块1
  15. If TransactionScope will close database connections
  16. CSS那些事!这个篇幅是我特意开的,不是因为帮助小菜之类的,而是在多人的团队配合中各种命名冲突的规范让人蛋疼
  17. panel内嵌程序窗体
  18. Java web实时进度条整个系统共用(如java上传、下载进度条、导入、导出excel进度条等)
  19. 洛谷P3527 MET-Meteors [POI2011] 整体二分
  20. asp.net—单例模式

热门文章

  1. mysql:unknown variable &#39;default-character-set=utf8&#39;
  2. godaddy SSL证书不信任
  3. PL/SQL中直接写SQL语句和用EXECUTE IMMEDIATE方法的区别
  4. 20175329&amp;20175313&amp;20175318 2019-2020 《信息安全系统设计基础》实验三
  5. Linux编程之recvmsg和sendmsg函数
  6. java调用exe,及调用bat不成功的解决办法
  7. 消息队列 RabbitMQ 入门介绍
  8. 001-tomcat下载、解压、启动、开机启动
  9. Hibernate 的一些注解配置
  10. HBase管理与监控——HBase region is not online