1. 程式人生 > >用EXCEL的VBA將PHPCMS的備份檔案轉換成HTML的一次嘗試

用EXCEL的VBA將PHPCMS的備份檔案轉換成HTML的一次嘗試

背景

有個PHPCMS的網站停了,但是網站的歷史文章又想要看看,網站停了以後,管理員發來了網站的所有資料。

分析

因為不會PHP,所有本地環境跑網站不優先考慮。

有MySQL資料庫檔案,但是不熟悉MySQL資料庫,也就不下載資料庫了。

有PHPCMS匯出的SQL檔案,但是不是標準的SQL檔案,不能用於匯入資料庫。不過這個文字格式的檔案已經包含了所有文章的內容。

嘗試

1.將v9_news 文章主表,v9_news_data 文章從表 用 vlook 函式拼接了一個 “news full”表。

2.用郵件合併的方式,直接生成了2000頁的DOC 文件。

3.但是文章的附件圖片未能顯示……

行動

1.將幾個SQL 合併成一個檔案。(匯出檔案是按照2MB進行了分割)

2.下載了 PHPCMS的資料字典。

3. 用到的表有: v9_news 文章主表,v9_news_data 文章從表,v9_attachment 附件表, v9_attachment_index 附件關係表

4.將這幾個表的插入語句用 VSCODE處理成 csv格式,匯入EXCEL。

5.mysql 資料庫的時間轉換到 excel的時間,用公式  =(Q2+8*3600)/86400+70*365+19,再用函式拼接成字串格式。

6.用 VBA 將記錄讀取到txt檔案中。

 1 Private Sub CommandButton1_Click()
 2 Dim fso As Object, sFile As Object
 3 Const ForReading = 1, ForWriting = 2, ForAppending = 8, TristateFalse = 0
 4 Set fso = CreateObject("Scripting.FileSystemObject")
 5 Set sFile = fso.OpenTextFile("d:\testfile.txt", ForAppending, TristateFalse)
6 For c = 2 To 1818 7 8 sFile.WriteLine "<div><h3>" + Sheet1.Cells(c, "d").Value + "</h3>" 9 sFile.WriteLine "<h5>日期:" + Sheet1.Cells(c, "w").Value + "</h5>" 10 For ccccc = 2 To 1818 11 wenzhangID = Sheet2.Cells(ccccc, "a") 12 If wenzhangID = Sheet1.Cells(c, "a") Then 13 NewsData = Sheet2.Cells(ccccc, "b").Value 14 sFile.WriteLine "<div>" & NewsData & "</div>" 15 End If 16 Next 17 'sFile.WriteLine "<div>" + getNewsData(Sheet1.Cells(c, "a")) + "</div>" 18 19 20 Dim keyArray() As Single 21 Dim i As Single '陣列計數 22 i = 0 23 For cc = 2 To 828 24 aid = Sheet4.Cells(cc, "c") 25 If aid = Sheet1.Cells(c, "a") Then 26 ReDim keyArray(i + 1) 27 keyArray(i) = Sheet4.Cells(cc, "d") 28 i = i + 1 29 End If 30 31 Next 32 If i > 0 Then 33 For Each aaa In keyArray 34 35 ' MsgBox aaa 36 37 For ccc = 2 To 746 38 39 ID = Sheet3.Cells(ccc, "a") 40 If ID = aaa Then 41 'MsgBox Sheet3.Cells(ccc, "e").Value 42 43 sFile.WriteLine "<img width=""100%"" src=uploadfile/" + Sheet3.Cells(ccc, "e").Value + " />" 44 End If 45 46 47 Next 48 49 50 51 Next 52 53 End If 54 55 56 57 sFile.WriteLine "</div>" 58 59 Next 60 61 sFile.Close 62 Set fso = Nothing 63 Set sFile = Nothing 64 MsgBox "OKOK!!!" 65 66 End Sub

遇到的問題

1. VBA 不熟悉,基本上都是貼上複製。做了幾個函式呼叫,總是有這樣那樣的問題,呼叫不成功,後來只好來個巢狀大法,層層嵌套了。

 1 Function getNewsData(m)
 2 
 3 For ccccc = 2 To 1818
 4         wenzhangID = Sheet2.Cells(ccccc, "a")
 5         If wenzhangID = m Then
 6         getNewsData = Sheet2.Cells(ccccc, "b").Value
 7         End If
 8         
 9         
10 Next
11 
12 End Function
13 
14 Function getKey(m)
15     'm是文章id
16     Dim keyArray() As Single
17     Dim i As Single '陣列計數
18     i = 0
19     For c = 2 To 828
20         aid = Sheet4.Cells(c, "c")
21         If aid = m Then
22         ReDim keyArray(i + 1)
23         keyArray(i) = Sheet4.Cells(c, "d")
24         i = i + 1
25         End If
26     
27     Next
28     ReDim keyArray(i + 1)
29     getKey = keyArray
30 End Function
31 
32 Function EmptyArr(ByRef x() As String) As Boolean  '判斷是否為空陣列的自定義函式
33 Dim tempStr As String
34 tempStr = Join(x, ",")
35 EmptyArr = LenB(tempStr) <= 0
36 End Function
幾個不成功的函式

2.如果單元格里面有連續四個空格的話,FileSystemObject.WriteLine 會報錯,不明白為什麼。

3.還有兩個單元格看起來沒有什麼特別的內容,FileSystemObject.WriteLine 也會報錯,原因不明,也不知道該怎樣分析,最後把單元格內容設定為“讀取錯誤”給跳過了。

4.變數名,格式啥的非常隨意,估計過幾天自己也不認得了。

5.認為這樣簡單的任務用 VBA 搞定應該很寬,但是沒想到在做迴圈的時候,竟然在怎樣判斷陣列的元素個數上搜了半天。

想法:

下次這樣的任務還是用 NOPI 做。