ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
300集Office 2010微视频教程 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
楼主: bluesky_0

[求助]怎样把EXCEL中的Flash文件提取出来啊?

[复制链接]

TA的精华主题

TA的得分主题

发表于 2008-8-5 22:59 | 显示全部楼层
QUOTE:
以下是引用chrisfang在2006-6-21 16:23:27的发言:

时钟集锦:

谢谢分享

TA的精华主题

TA的得分主题

发表于 2008-8-6 09:58 | 显示全部楼层

用以下代码可以转出flash文件:

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
OldName = Left(tmpFileName, Len(tmpFileName) - 4)
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
            myFileId = FreeFile
            tmpFileName = OldName & i & ".swf"
            Open tmpFileName For Binary As #myFileId
            Put #myFileId, , swfArr
            Close myFileId
            i = i + swfFileLen + 8
        Else
            i = i + 3
        End If
    Else
        i = i + 1
    End If
Loop
MsgBox "以" & OldName & "1-n.swf 名字保存"
End Sub

TA的精华主题

TA的得分主题

 楼主| 发表于 2008-8-8 12:21 | 显示全部楼层
QUOTE:
以下是引用冰弦曳指在2008-8-6 9:58:44的发言:

用以下代码可以转出flash文件:

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
OldName = Left(tmpFileName, Len(tmpFileName) - 4)
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
            myFileId = FreeFile
            tmpFileName = OldName & i & ".swf"
            Open tmpFileName For Binary As #myFileId
            Put #myFileId, , swfArr
            Close myFileId
            i = i + swfFileLen + 8
        Else
            i = i + 3
        End If
    Else
        i = i + 1
    End If
Loop
MsgBox "以" & OldName & "1-n.swf 名字保存"
End Sub

非常感谢!可是找不到库阿! 


[此贴子已经被作者于2008-8-8 12:27:08编辑过]
yLO99WlK.jpg

TA的精华主题

TA的得分主题

发表于 2008-8-12 14:01 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2008-9-22 18:14 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2008-9-24 02:14 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2008-10-21 21:10 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册

我来的迟了啊,但我要感谢楼主,从这里我学到了不少,虽然我还是差的很很远!

TA的精华主题

TA的得分主题

发表于 2008-12-17 10:43 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
学会了
多谢版主

TA的精华主题

TA的得分主题

发表于 2008-12-24 17:18 | 显示全部楼层

从excel 或word提取flash文件

1.        打开一个新的excel文档。
2.        单击 Tools > Macro > Visual Basic Editor. 你也可以按ALT +F11热键来打开VBA编辑器。
3.        在VBA编辑器中,单击面板左上方的View Code图标。
4.        将下面的VBA程序源代码拷贝粘贴到VBA编辑器中。
5.        按F5来执行源代码。
6.        出来一个Open File对话框,提示你选择嵌入了flash动画文件的excel 文档。
7.        选择了excel 文档之后很快会出来一个消息框,告诉你提取出来的flash动画文件保存在了哪里。


从excel 或word中提取动画文件的源代码如下:
  1. Sub ExtractFlash()

  2. Dim tmpFileName As String
  3. Dim FileNumber As Integer
  4. Dim myFileId As Long
  5. Dim MyFileLen As Long
  6. Dim myIndex As Long
  7. Dim swfFileLen As Long
  8. Dim i As Long
  9. Dim swfArr() As Byte
  10. Dim myArr() As Byte

  11. tmpFileName = Application.GetOpenFilename("MS Office File (*.doc;*.xls), *.doc;*.xls", , "Open MS Office file")

  12. If tmpFileName = "False" Then Exit Sub

  13. myFileId = FreeFile

  14. Open tmpFileName For Binary As #myFileId

  15. MyFileLen = LOF(myFileId)

  16. ReDim myArr(MyFileLen - 1)

  17. Get myFileId, , myArr()

  18. Close myFileId

  19. Application.ScreenUpdating = False

  20. i = 0

  21. Do While i < MyFileLen

  22.    If myArr(i) = &H46 Then

  23.       If myArr(i + 1) = &H57 And myArr(i + 2) = &H53 Then

  24.          swfFileLen = CLng(&H1000000) * myArr(i + 7) + CLng(&H10000) * myArr(i + 6) + CLng(&H100) * myArr(i + 5) + myArr(i + 4)

  25.          ReDim swfArr(swfFileLen - 1)

  26.          For myIndex = 0 To swfFileLen - 1
  27.             swfArr(myIndex) = myArr(i + myIndex)
  28.             Next myIndex
  29.          Exit Do

  30.       Else
  31.             i = i + 3
  32.       End If

  33.    Else
  34.         i = i + 1
  35.    End If

  36. Loop

  37. myFileId = FreeFile

  38. tmpFileName = Left(tmpFileName, Len(tmpFileName) - 4) & ".swf"

  39. Open tmpFileName For Binary As #myFileId

  40. Put #myFileId, , swfArr

  41. Close myFileId

  42. MsgBox "Save the extracted SWF Flash as [ " & tmpFileName & " ]"

  43. End Sub
复制代码

TA的精华主题

TA的得分主题

发表于 2009-1-19 10:39 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
是啊,已经嵌入的swf文件如何提取出来??
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-7-2 08:39 , Processed in 0.043618 second(s), 8 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

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