2016-12-29 16 views
0

"ConversiePDF"シートをPDFに変換するVBAコードがあります。
問題は、シート全体は、式によって生成されることがあり、(「」実行しかし復帰式と)シートの半分がデータで埋めbeeingてされており、他の半分は空白のままVBA:変換中の空白セルを無視するスクリプトに変換する

私のコードは、シート全体を変換行1000まで移動して32ページを生成します(魔法使い30は空白です - 実際のデータのないテーブルのみ)

数式が返された空白のセルを無視する必要があります。 Qが空であるか、 ""を返します。 (行からのみ一から二、三のセルが空の場合、これは適用しないでください)

が..

'This is my code till now: 

Dim ThisRng As Range 
Dim strfile As String 
Dim myfile As Variant 

'Selectie Sheet pentru conversie 
With ActiveWorkbook.Sheets("ConversiePDF") 
Set ThisRng = .Range("A2", .Cells(.Rows.Count, "F").End(xlUp)) 
End With 

を助けてください..

+0

をありがとう、あなたは(フィルタを試してみましたout empyt rows)を手動またはVBAコードで設定できますか?すべての列をチェックする必要はありません。行が空であるかどうかを判断するのに十分な場合もあります。 'SUM()'や 'COUNT()'(あるいはあなたが持っているデータのタイプに応じて他のCOUNT式)をチェックし、行が空であるかどうかを判断して非表示にすることもできます。 –

+0

私はExcelのフィルタでチェックし、それは動作します。残りのセルをpdfに変換するだけですが、私はvbaでそれを必要とします。私は正しいコードのインターネットをチェックしていますが、私は(おそらく私はVBAと比較的馬鹿です) – MisterA

+0

Ok。私は、値を持つセルだけをPDFに変換する次のコードを取得することができましたが、シートから戻ってくる式も削除しました。 "私はそれらの数式をシートに残す必要がありますが(永久に)、 ""ならばpdfには表示されません。
コード:Selection.AutoFilter Selection.AutoFilterフィールド:= 1、Criteria1:= "<>" 'カラム Selection.AutoFilterフィールド:= 5、Criteria1:= "<>"'カラムE – MisterA

答えて

0
Private Sub CommandButton1_Click() 
'BUTON CONVERSIE PDF - ANGAJATORI 
'DESCRIPTION: CONVERSIE A UNUI SHEET IN PDF 
Dim ThisRng As Range 
Dim strfile As String 
Dim myfile As Variant 


'Selectie Sheet pentru conversie 
Application.ScreenUpdating = False 
ActiveWorkbook.Sheets("PDF ANG").Visible = True 

'Selectie filtru pentru ce sa converteasca 
ActiveWorkbook.Sheets("PDF ANG").Select 
Selection.AutoFilter Field:=1, Criteria1:="<>" 'column A 
Selection.AutoFilter Field:=5, Criteria1:="<>" 'column E 

'Selectie raza pentru conversie 
With ActiveWorkbook.Sheets("PDF ANG") 
Set ThisRng = .Range("A2", .Cells(.Rows.Count, "F").End(xlUp)) 
End With 

'Prompt for save location 
strfile = "Selection" & "_" _ 
& Format(Now(), "yyyymmdd_hhmmss") _ 
& ".pdf" 
strfile = ThisWorkbook.Path & "\" & strfile 
myfile = Application.GetSaveAsFilename _ 
(InitialFileName:=strfile, _ 
FileFilter:="PDF Files (*.pdf), *.pdf", _ 
Title:="Select Folder and File Name to Save as PDF") 
If myfile <> "False" Then 'save as PDF 
ThisRng.ExportAsFixedFormat Type:=xlTypePDF, Filename:= _ 
myfile, Quality:=xlQualityStandard, IncludeDocProperties:=True, _ 
IgnorePrintAreas:=False, OpenAfterPublish:=True 
Else 
MsgBox "No File Selected. PDF will not be saved", vbOKOnly, "No File Selected" 
End If 
ActiveWorkbook.Sheets("PDF ANG").ShowAllData 
ActiveWorkbook.Sheets("PDF ANG").Visible = False 

End Sub 
+0

はこのように動作します – MisterA

関連する問題