版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、批量打印的VBA程序一項(xiàng)任務(wù)的要求是把表1按照表2填寫(xiě)完整后,打印輸出。如果人多的話,這項(xiàng)工作很是繁瑣,所以我寫(xiě)了一個(gè)VBA程序,讓工作自動(dòng)進(jìn)行。后來(lái),這個(gè)程序的思路還發(fā)表的論文。Option ExplicitDim Arr() '定義要打印的記錄的行號(hào)為可變數(shù)組,用來(lái)保存要打印的記錄的行號(hào)Dim LastRow%, PrePage%, FindNameRow% '定義數(shù)據(jù)表中的最后一行行號(hào)、向?qū)г诘诙綍r(shí)的頁(yè)面、找到的姓名所在的行Dim OutToPrint As Boolean
2、60; '定義是否輸出到打印機(jī)Private Sub CBcancel_Click() Unload MeEnd SubPrivate Sub CBfinish_Click() Dim i%, j% Dim myadd() UFPrint.Hide myadd = Array("C2", "E2&
3、quot;, "G2", "C3", "E3", "G3", "C4", "C5", "F5", "C6", "C7", "E7", "C8", "E8", "C9", "E9", "G9", "C10", "E10", "G10", &q
4、uot;B11") ' 定義需輸入內(nèi)容的單元格地址為數(shù)組 For i = LBound(Arr) To UBound(Arr) ' 循環(huán)提取數(shù)據(jù)表中需要處理的記錄 For j = LBound(myadd) To UBound(myad
5、d) ' 循環(huán)提取各字段數(shù)據(jù) Sheets("print").Range(myadd(j).Value = Sheets("data").Cells(Arr(i), j + 1).Value '
6、0; 將數(shù)據(jù)填入到表格中 Next j If OutToPrint Then Sheets("print").PrintOut ' 打印 If Not OutToPrint Then Sheets(
7、"print").PrintPreview '打印預(yù)覽 DoEvents Next UFPrint.MultiPage1.Value = 0 '到第一個(gè)頁(yè)面 UFPrint.ShowEnd SubPrivate Sub CBnext_Cli
8、ck() Dim i%, SelCount%, MyCount%, ChangePage% Select Case MultiPage1.Value '判斷按下“下一步”按鈕時(shí)的頁(yè)面 Case 0 '第一個(gè)頁(yè)面 If OptionButton1.Value = True
9、Then ChangePage = 1 If OptionButton2.Value = True Then ChangePage = 2 If OptionButton3.Value = True Then ChangePage = 3 '根據(jù)所做的選擇,分別設(shè)置將要跳到哪一個(gè)頁(yè)面 &
10、#160; Case 1 '第二個(gè)頁(yè)面 If Val(TextBox1) < 2 Or Val(TextBox1) > LastRow Or Val(TextBox2) < 2 Or Val(TextBox2) > LastRow Then MsgBox "數(shù)值應(yīng)大
11、于等于2,小于等于" & LastRow, vbOKOnly + vbExclamation, "提示" TextBox1 = 2 TextBox2 = 2 &
12、#160; Exit Sub End If '如果數(shù)據(jù)不符合要求,退出過(guò)程 ReDim Arr(CInt(TextBox1) To CInt(TextBox2) '重新定義數(shù)組
13、; For i = LBound(Arr) To UBound(Arr) Arr(i) = i Next i '將數(shù)據(jù)寫(xiě)入數(shù)組 ChangePag
14、e = 4 '設(shè)置要轉(zhuǎn)到的下一個(gè)頁(yè)面 Case 2 '第三個(gè)頁(yè)面 SelCount = 0 For i = 0 To ListBox1.ListCount - 1
15、 If ListBox1.Selected(i) Then SelCount = SelCount + 1 Next i '得到共有多少條記錄被選擇 ReDim Arr(1 To SelCount) '重新定義數(shù)組
16、0; MyCount = 1 For i = 0 To ListBox1.ListCount - 1 If ListBox1.Selected(i) Then
17、160; Arr(MyCount) = CInt(ListBox1.List(i, 0) MyCount = MyCount + 1 End If
18、160; Next i '將數(shù)據(jù)寫(xiě)入數(shù)組 ChangePage = 4 '設(shè)置要轉(zhuǎn)到的下一個(gè)頁(yè)面 Case 3 '第四個(gè)頁(yè)面 Call CommandButt
19、on2_Click '調(diào)用“查找”,確定能否找到記錄 If FindNameRow = 0 Then '不能找到記錄 MsgBox "找不到姓名為<" & TextBox3 & ">的記錄,<下一步>按鈕不起作
20、用!", vbOKOnly + vbExclamation, "錯(cuò)誤提示" Exit Sub '退出過(guò)程 End If ReDim Arr(1 To 1)
21、0;'重新定義數(shù)組 Arr(1) = FindNameRow ChangePage = 4 '設(shè)置要轉(zhuǎn)到的下一個(gè)頁(yè)面 End Select MultiPage1.Value = ChangePage '切
22、換頁(yè)面End SubPrivate Sub CBpre_Click() Dim ChangePage% Select Case MultiPage1.Value Case 1, 2, 3 ChangePage = 0 Case 4
23、0;ChangePage = PrePage '讀取前一頁(yè)的信息 End Select MultiPage1.Value = ChangePageEnd SubPrivate Sub CommandButton2_Click() Dim i% FindNameRow = 0 For i = 2 To LastRow
24、 If Sheets("data").Cells(i, 1) = TextBox3.Text Then FindNameRow = i Exit For &
25、#160; End If Next i If FindNameRow = 0 Then Label9.Caption = "未找到記錄,請(qǐng)修改姓名后再試" CBnext.Enabled = False Else
26、; Label9.Caption = "可以找到記錄,請(qǐng)繼續(xù)下一步" CBnext.Enabled = True End IfEnd SubPrivate Sub MultiPage1_Change() Dim i% Dim MyStep$ &
27、#160;Select Case MultiPage1.Value Case 0 CBpre.Enabled = False CBnext.Enabled = True CBfinish.Enabled = False
28、60; MyStep = "一" Case 1 CBpre.Enabled = True CBnext.Enabled = True CBfinish.Enabled = False
29、 PrePage = 1 MyStep = "二" Case 2 '重新加載listbox1中的數(shù)據(jù) ListBox1.Clear '清除列表框
30、中的原有內(nèi)容 For i = 2 To LastRow ListBox1.AddItem i ListBox1.List(i - 2, 1) = Sheets("data").Cells(i, 1)
31、160; '在列表框的第二列中添加姓名 Next i ListBox1.Selected(0) = True '將第一條記錄設(shè)置為選擇狀態(tài) CBpre.Enabled = True
32、60; CBnext.Enabled = True CBfinish.Enabled = False PrePage = 2 MyStep = "二" Case 3
33、60; CBnext.Enabled = IIf(Left(Label9.Caption, 1) = "可", True, False) CBpre.Enabled = True CBfinish.Enabled = False PrePage = 3
34、 MyStep = "二" Case 4 CBpre.Enabled = True CBnext.Enabled = False CBfinish.Enabled = True
35、60; MyStep = "三" End Select UFPrint.Caption = "批量打印信息收集向?qū)?第" & MyStep & "步,共三步" '更改窗體的題目End SubPrivate Sub OptionButton4_Click() OutToPrint = FalseEnd SubPrivate Sub OptionButton5_Click() OutToPrint = TrueEnd SubPrivate Sub S
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五版泥工施工環(huán)保評(píng)估及監(jiān)測(cè)服務(wù)合同2篇
- 中小企業(yè)綠色環(huán)保生產(chǎn)技術(shù)改造2025年實(shí)施合同
- 二零二五年度新型農(nóng)民合作社成員入社合同范本
- 二零二五年度摩托車(chē)行業(yè)技術(shù)交流合作合同
- 山東省17地市2013一模語(yǔ)文分解-文學(xué)類文本閱讀
- 2025年度個(gè)人獨(dú)資企業(yè)股權(quán)買(mǎi)賣(mài)合同模板
- 二零二五年度真石漆施工項(xiàng)目風(fēng)險(xiǎn)評(píng)估與管理合同2篇
- 二零二五年度程序員入職心理健康關(guān)愛(ài)與支持合同4篇
- 二零二五年度儲(chǔ)藏煤場(chǎng)租賃合同附煤炭?jī)?chǔ)存環(huán)境影響評(píng)估4篇
- 二零二五版某某金融資產(chǎn)證券化項(xiàng)目補(bǔ)充合同3篇
- 四川省宜賓市2023-2024學(xué)年八年級(jí)上學(xué)期期末義務(wù)教育階段教學(xué)質(zhì)量監(jiān)測(cè)英語(yǔ)試題
- 價(jià)值醫(yī)療的概念 實(shí)踐及其實(shí)現(xiàn)路徑
- 2024年中國(guó)華能集團(tuán)燃料有限公司招聘筆試參考題庫(kù)含答案解析
- 《紅樓夢(mèng)》中的男性形象解讀
- 安全生產(chǎn)技術(shù)規(guī)范 第49部分:加油站 DB50-T 867.49-2023
- 《三國(guó)演義》中的語(yǔ)言藝術(shù):詩(shī)詞歌賦的應(yīng)用
- 腸外營(yíng)養(yǎng)液的合理配制
- 消防安全教育培訓(xùn)記錄表
- 2023年河南省新鄉(xiāng)市鳳泉區(qū)事業(yè)單位招聘53人高頻考點(diǎn)題庫(kù)(共500題含答案解析)模擬練習(xí)試卷
- 2023年小升初簡(jiǎn)歷下載
- 廣府文化的奇葩
評(píng)論
0/150
提交評(píng)論