|
如何导出excel中的flash
经常从网上下载一些flash小游戏,有一些flash是被嵌入到excel中的,有时收到的excel中也会有一些漂亮的flash,很想单独保存出来据为己有。
先来介绍下如何向excel中添加flash:
1.首先开启一个空白Excel文件,在功能表的空白处按鼠标右键,选【控制工具箱】,启用「控制工具箱」工具列。
2.出现「控制工具箱」工具列后,在「其他控制项」按钮上按鼠标右键,然后再点击「Shockwave Flash Object」项目,表示要插入Flash物件。
3.接鼠标会变成一个小十字的图案,此时可以在Excel编辑区中划一个大小适中的方框,这个方框就是用来显示Flash动画的内容的。
4. 画好方框后,在物件上方按一下滑鼠右键并点选功能表中的【属性】,准备设定该物件的属性。
5. 出现「属性」对话框后,在页面中找到「Movie」这个项目,并在其右边的方框中输入你的Flash档的网址,输入完毕再按一下右上角的〔X〕关闭此对话盒即可。
6. 回到Excel编辑页面后,点一下「控制工具箱」工具列最左边的〔结束设计模式〕按钮,恢复一般模式。
7. 设定好该物件的属性并回到一般编辑模式后,我们便可看到Excel档案中出现了刚刚贴上的Flash档内容。
接下来介绍如何从excel中导出flash保存为.swf格式的文件:
1. 点击工具——>宏——>宏
2. 弹出一个宏创建窗体,在窗口中输入宏名(例如:宏名:ExtractFlash)点击创建按钮。
3. 弹出一个编程界面,在界面的中间有一个小窗口,在窗口中输入下面的程序段。
Sub ExtractFlash()
Dim tmpFileName As String, FileNumber As Integer
Dim myFileId As Long
Dim myArr() As Byte
Dim i As Long
Dim MyFileLen As Long, myIndex As Long
Dim swfFileLen As Long
Dim swfArr() As Byte
tmpFileName = Application.GetOpenFilename("office File(*.doc;*.xls),*.doc;*.xls", , "确定要分析的 Office 档")
If tmpFileName = "False" Then Exit Sub
myFileId = FreeFile
Open tmpFileName For Binary As #myFileId
MyFileLen = LOF(myFileId)
ReDim myArr(MyFileLen - 1)
Get myFileId, , myArr()
Close myFileId
Application.ScreenUpdating = False
i = 0
Do While i < MyFileLen
If myArr(i) = &H46 Then
If myArr(i + 1) = &H57 And myArr(i + 2) = &H53 Then
swfFileLen = CLng(&H1000000) * myArr(i + 7) + CLng(&H10000) * myArr(i + 6) + CLng(&H100) * myArr(i + 5) + myArr(i + 4)
ReDim swfArr(swfFileLen - 1)
For myIndex = 0 To swfFileLen - 1
swfArr(myIndex) = myArr(i + myIndex)
Next myIndex
Exit Do
Else
i = i + 3
End If
Else
i = i + 1
End If
Loop
myFileId = FreeFile
tmpFileName = Left(tmpFileName, Len(tmpFileName) - 4) & ".swf"
Open tmpFileName For Binary As #myFileId
Put #myFileId, , swfArr
Close myFileId
MsgBox "以" & tmpFileName & "名字保存"
End Sub
4. 按F5运行宏。
5. 弹出一个选择文件的窗口,选择你想要提取flash的excel文件,点击打开按钮。
6. 这时会弹出一个提示窗口“以....名字保存”,点击确定。
7. 在excel所在的位置会产生一个同名的flash文件。到此flash文件已经导出了。
一般的操作很难导出,只能采取分析文件的办法导出,因为SWF是有数据格式的,有不一样的PE头,所有能够分析导入。
|
|