BlenderCN论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 2262|回复: 1

python win32com 创建Wscript.Shell进行自动化

[复制链接]
发表于 2013-8-23 16:56:23 | 显示全部楼层 |阅读模式
我担心以后找不到文章,就复制过来了,请作者谅解我的偷偷搬运。
另外,似乎win32com 并不能访问blender. 只是让大家了解下py的其他用途。包括操作浏览器、office等等。

http://www.linuxany.com/archives/594.html


  1. import win32com.client

  2. execpath = 'cmd.exe'
  3. wsh = win32com.client.Dispatch("Wscript.Shell")
  4. wshe = wsh.Exec(execpath)
  5. pid = wshe.ProcessID
  6. wsh.AppActivate(pid)
  7. time.sleep(splashsec)
  8. wsh.SendKeys("{ENTER}")
  9. wsh.SendKeys("%n")#alt+n
  10. wsh.SendKeys("%a")
  11. wsh.SendKeys("10.0.0.1")
  12. wsh.SendKeys("{CAPSLOCK}")
复制代码



object.SendKeys(string)
参数
object WshShell 对象。
string 表示要发送的键击(一个或多个)的字符串值。
说明
使用 SendKeys 方法可以将键击发送到无自动化界面的应用程序中。多数键盘字符都可用一个键击表示。某些键盘字符由多个键击组合而成(例如,CTRL+SHIFT+ HOME)。要发送单个键盘字符,请将字符本身作为 string 参数发送。例如,要发送字母 x,则请发送 string 参数 “x”。
注意 要发送空格,则请发送字符串 ” “。
可使用 SendKeys 同时发送多个键击。为此,可将每个键击按顺序排列在一起,以此来创建表示一系列键击的复合字符串参数。例如,要发送键击 a、b 和 c,则需要发送字符串参数 “abc”。SendKeys 方法将某些字符用作字符的修饰符(而不使用其本身的含义)。这组特殊的字符可包括圆括号、中括号、大括号,以及:
加号 “+”、
插入记号 “^”、
百分号 “%”、
和“非”符号 “~”。
用大括号 “{}” 括起这些字符可以发送它们。例如,要发送加号,请使用字符串参数 “{+}”。SendKeys中使用的中括号 “[ ]” 无任何特殊含义,但是必须把它们括在大括号中,以便容纳确实要赋予其特殊含义的应用程序(例如,对于动态数据交换 (DDE) 就是这样)。
要发送左中括号字符,请发送字符串参数 “{[]“;要发送右中括号字符,请发送字符串参数 “{]}”。
要发送左大括号字符,请发送字符串参数 “{{}”;要发送右大括号字符,请发送字符串参数 “{}}”。
某些键击不生成字符(如 ENTER 和 TAB)。某些键击表示操作(如 BACKSPACE 和 BREAK)。要发送这些类型的键击,请发送下表中列出的参数:
键        参数
退格键 {BACKSPACE}、{BS} 或 {BKSP}
BREAK {BREAK}
CAPS LOCK {CAPSLOCK}
DEL 或 DELETE {DELETE} 或 {DEL}
向下键 {DOWN}
END {END}
ENTER {ENTER} 或 ~
ESC {ESC}
HELP {HELP}
HOME {HOME}
INS 或 INSERT {INSERT} 或 {INS}
向左键 {LEFT}
NUM LOCK {NUMLOCK}
PAGE DOWN {PGDN}
PAGE UP {PGUP}
PRINT SCREEN {PRTSC}
向右键 {RIGHT}
SCROLL LOCK {SCROLLLOCK}
TAB {TAB}
向上键 {UP}
F1 {F1}
F2 {F2}
F3 {F3}
F4 {F4}
F5 {F5}
F6 {F6}
F7 {F7}
F8 {F8}
F9 {F9}
F10 {F10}
F11 {F11}
F12 {F12}
F13 {F13}
F14 {F14}
F15 {F15}
F16 {F16}
要发送由常规键击和 SHIFT、CTRL 或 ALT 组合而成的键盘字符,请创建表示该键击组合的复合字符串参数。可通过在常规键击之前添加一个或多个以下特殊字符来完成上述操作:
键       特殊字符
SHIFT +
CTRL ^
ALT %
注意 这样使用时,不用大括号括起这些特殊字符。
要指定在按下多个其他键时,按下 SHIFT、CTRL 和 ALT 的组合,请创建复合字符串参数,用括号括起其中的组合键。例如,要发送的组合键指定:
如果在按 e 和 c 的同时按 SHIFT 键,则发送字符串参数 “+(ec)”。
如果在按 e 时只按 c(而不按 SHIFT),则发送字符串参数 “+ec”。
可使用 SendKeys 方法发送一种在一行内重复按键的键击。为此,要创建复合字符串参数,以指定要重复的键击,并在其后指定重复次数。可使用 {键击 数字} 形式的复合字符串参数来完成上述操作。例如,如果要发送 10 次 “x”,则需要发送字符串参数 “{x 10}”。请确保在键击和数字之间有一个空格。


 楼主| 发表于 2013-8-23 17:10:53 | 显示全部楼层
对wps的操作测试,似乎与mso差不了多少,不过,我不用mso。
另外,libreOffice似乎直接就支持python macro. 见范例:
z:\Program Files (x86)\LibreOffice 4\share\Scripts\python
需要提醒的是libreO并没有多少与此相关内容,但是可以看OpenOfficeOrg的,因为OOo历史悠久,和LO是一个血脉。

  1. # -*- coding:utf-8 -*-

  2. def NewDoc():
  3.     import win32com.client
  4.     """新建WPS进程"""
  5.     wpsApp = win32com.client.Dispatch( "wps.Application" )
  6.     wpsApp.Visible = 1
  7.     wpsdoc = wpsApp.Documents.Add()
  8.     wpsdoc.content.text = "Hello World!"
  9.     wpsdoc.SaveAs("C:/Users/Administrator/Desktop/00/HelloWorld.doc")
  10.     wpsdoc.Close()
  11.     wpsApp.Quit()
  12.     del(wpsApp)

  13. def Excel1():
  14.     import win32com.client
  15.     #新建WPS进程
  16.     #wps、et、wpp对应的是金山文件、表格和演示
  17.     #word、excel、powerpoint对应的是微软的文字、表格和演示
  18.     wpsApp=win32com.client.Dispatch("et.Application")
  19.     #设置界面可见
  20.     wpsApp.Visible=1
  21.     #新建一个wps工作簿
  22.     xlBook = wpsApp.Workbooks.Add()
  23.     #选定工作簿中活动工作表的某个单元格
  24.     cell = xlBook.ActiveSheet.Cells(1,1)
  25.     #设置单元格的值
  26.     cell.Value='one'
  27.     #保存工作簿
  28.     xlBook.SaveAs("c:/HelloWorld.xls")
  29.     xlBook.Close()
  30.     wpsApp.Quit()
  31.     del(wpsApp)

  32. def Excel2():
  33.     from win32com.client import constants, Dispatch

  34.     wpsApp = Dispatch("et.Application")
  35.     # 通过赋值Visible为True或者False可以控制是否调出excle
  36.     wpsApp.Visible = 1

  37.     # xlsBook = wpsApp.Workbooks.Open("c://magictong.xls")
  38.     # xlsBook = wpsApp.Workbooks('Book3')  #xls名字
  39.     # xlsSht = xlsBook.Worksheets("sheet1")

  40.     # mytable = wpsApp.ActiveDocument.Tables(1)  # ActiveDocument.Tables(1).Select #激活第一个表
  41.     # "第一个表有" mytable.Columns.Count & "列" mytable.Rows.Count & "行"

  42.     xlsBook = wpsApp.Workbooks.Add()
  43.     # xlsSht = xlBook.ActiveSheet
  44.     xlsSht = xlsBook.Sheets.Add()
  45.     # xlsSht = xlBook.Sheets('Sheet1') #指定表单

  46.     xlsSht.Cells(2, 3).Value = "Tecent QQ"
  47.     xlsSht.Cells(2, 3).Font.Color = 0xff0000

  48.     xlsSht.Name = "GCD go to hell"
  49.     # xlsBook.SaveAs("c:/magictong.xls")
  50.     # wpsApp.Quit()
  51.     # del(wpsApp)

  52.     # wpsApp.Application.Selection '设定选中范围
  53.     # wpsApp.ActiveSheet.Pictures.Insert("XXXXX.jpg").Select '插入图片并选中



  54. def Run():
  55.     Excel2()

  56. if __name__  ==  "__main__":
  57.     Run()

复制代码


下面不是python的,但有兴趣的同学可以参考
WPS办公软件操作说明.doc

高效办公使用技巧培训教程 - WPS
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

站长推荐上一条 /1 下一条

Blender最新中文教学视频|Blender头条|小黑屋|手机版|Archiver|Blender中国 ( 蜀ICP备17002929号 )360网站安全检测平台

GMT+8, 2019-9-15 18:51 , Processed in 0.029672 second(s), 21 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表