• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Lua通过COM调用外部程序excel及调用windowsapi

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

from http://sunxiunan.com/?p=1258

为了方便起见,最好安装lua for windows,里面已经包含了很多有用的第三方模块。

require(’luacom’) — luacom
ie = luacom.CreateObject(”InternetExplorer.Application”)
ie:Navigate2(”http://sunxiunan.com”)

ie.Visible = true

使用lua调用excel,然后往cell里面填一些数据。

require(’luacom’) — luacom
– Excelの起動
excel = luacom.CreateObject(”Excel.Application”)
excel.Visible = true — 可視状態に
– ワークブックを追加
local book  = excel.Workbooks:Add()

local sheet = book.Worksheets(1)
– 適当な値を100個書き込む
for row=1,100 do
  sheet.Cells(row, 1).Value2 = math.floor(math.random() * 20)
end

稍微复杂一些的代码

require “luacom”
excel = luacom.CreateObject(”Excel.Application”)
local book  = excel.Workbooks:Add()
local sheet = book.Worksheets(1)
excel.Visible = true

– 適当な値を書き込む
for row=1,30 do
  for col=1,30 do
    sheet.Cells(row, col).Value2 = math.floor(math.random() * 100)
  end
end
– 値を調べて50以上のものを黄色でマークする
local range = sheet:Range(”A1″)
for row=1,30 do

  for col=1,30 do
    local v = sheet.Cells(row, col).Value2
    if v > 50 then
          local cell = range:Offset(row-1, col-1)
          cell:Select()
          excel.Selection.Interior.Color = 65535
        end
  end

end

excel.DisplayAlerts = false — 終了確認を出さないようにする

excel:Quit()
excel = nil

如果想给excel加个图表该怎么做?

require “luacom”
excel = luacom.CreateObject(”Excel.Application”)
local book  = excel.Workbooks:Add()
local sheet = book.Worksheets(1)
excel.Visible = true

for row=1,30 do
  sheet.Cells(row, 1).Value2 = math.floor(math.random() * 100)
end

local chart = excel.Charts:Add()
chart.ChartType = 4 — xlLine
local range = sheet:Range(”A1:A30″)

chart:SetSourceData(range)

如果想调用windows api,可以用下面的代码

require “alien”

MessageBox = alien.User32.MessageBoxA
MessageBox:types{ret = ‘long’, abi = ’stdcall’, ‘long’, ’string’,
’string’, ‘long’ }

MessageBox(0, “title for test”, “LUA call windows api”, 0)

如何实现回调函数呢?下面的例子展示了回调。

require ‘alien’
–声明了两个函数EnumWindows和GetClassName
EnumWindows = alien.user32.EnumWindows
EnumWindows:types {”callback”, “pointer”, abi=”stdcall”}

GetClassName = alien.user32.GetClassNameA
GetClassName:types {”long”, “pointer”, “int”, abi=”stdcall” }

local buf = alien.buffer(512)

– 会被EnumWindows反复调用,传入windows的handle
local function enum_func(hwnd, p)

  GetClassName(hwnd, buf, 511)
  print (hwnd..”:”..tostring(buf))
  return 1
end
local callback_func = alien.callback(
        enum_func,
        {”int”, “pointer”, abi=”stdcall”})

EnumWindows(callback_func, nil)

其中函数原型是

BOOL EnumWindows(WNDENUMPROC lpEnumFunc, LPARAM lParam);
int GetClassName(HWND hWnd, LPTSTR lpClassName, int nMaxCount);
 
其中EnumWindows第一个参数的原型为,这个函数是客户调用时候传入,EnumWindows用它返回
BOOL CALLBACK EnumWindowsProc(HWND hwnd, LPARAM lParam);
其他复杂的使用方法可以参考alien的文档。
 

这些代码都来自www.hakkaku.net/articles/20090615-459


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap