எக்செல் தரவை வேர்டில் திறம்பட இணைத்தல்
வெவ்வேறு தளங்களில் தரவை நிர்வகிப்பது ஒரு சிக்கலான பணியாகும், குறிப்பாக நீங்கள் எக்செல் இலிருந்து பல அட்டவணைகளை ஒரு வேர்ட் ஆவணத்தில் தொகுக்க வேண்டியிருக்கும் போது. VBA ஐப் பயன்படுத்தி, நீங்கள் இந்த செயல்முறையைத் தானியங்குபடுத்தலாம், விரும்பிய வடிவம் மற்றும் கட்டமைப்பைப் பராமரிக்கும் போது தரவு தடையற்ற பரிமாற்றத்தை உறுதி செய்யலாம்.
இந்தக் கட்டுரை தற்போது எக்செல் அட்டவணையில் இருந்து மூன்று தனித்தனி வேர்ட் ஆவணங்களை உருவாக்கும் VBA மேக்ரோவை ஆராய்கிறது. அனைத்து அட்டவணைகளையும் ஒரே வேர்ட் ஆவணத்தில் உருவாக்க குறியீட்டை எவ்வாறு மாற்றுவது என்பதை நாங்கள் விளக்குவோம், தெளிவு மற்றும் ஒழுங்கமைப்பிற்காக ஒவ்வொரு அட்டவணைக்குப் பிறகு பக்க இடைவெளிகளுடன்.
| கட்டளை | விளக்கம் |
|---|---|
| Set wdApp = New Word.Application | வேர்ட் பயன்பாட்டின் புதிய நிகழ்வைத் துவக்குகிறது. |
| wdDoc.Characters.Last.InsertBreak Type:=wdPageBreak | ஆவணத்தின் முடிவில் பக்க இடைவெளியைச் செருகும். |
| .Rows(1).HeadingFormat = True | அட்டவணையின் முதல் வரிசை ஒரு தலைப்பு வரிசை என்று குறிப்பிடுகிறது. |
| .Tables.Add(Range:=wdDoc.Range, NumRows:=2, NumColumns:=lCol) | குறிப்பிட்ட வரிசைகள் மற்றும் நெடுவரிசைகளுடன் Word ஆவணத்தில் புதிய அட்டவணையைச் சேர்க்கிறது. |
| With wdTbl.Borders | கோடுகளுக்கு உள்ளேயும் வெளியேயும் அட்டவணையின் எல்லைப் பாணியை அமைக்கிறது. |
| wdApp.Visible = True | வேர்ட் அப்ளிகேஷனை பயனருக்குத் தெரியும்படி செய்கிறது. |
| If (r - startRow + 2) >If (r - startRow + 2) > .Rows.Count Then .Rows.Add | தற்போதைய வரிசை ஏற்கனவே உள்ள வரிசை எண்ணிக்கையை விட அதிகமாக இருந்தால், அட்டவணையில் புதிய வரிசையைச் சேர்க்கும். |
| Set wdDoc = .Documents.Add | Word பயன்பாட்டில் புதிய ஆவணத்தை உருவாக்குகிறது. |
அட்டவணைகளை இணைப்பதற்கான VBA மேக்ரோவைப் புரிந்துகொள்வது
வழங்கப்பட்ட ஸ்கிரிப்டுகள் VBA ஐப் பயன்படுத்தி பல எக்செல் டேபிள்களில் இருந்து ஒரு வேர்ட் டாகுமெண்ட்டில் தரவை எவ்வாறு தானியங்குபடுத்துவது என்பதை விளக்குகிறது. முக்கிய ஸ்கிரிப்ட், Sub ConsolidateTablesInOneDocument(), உடன் வேர்ட் பயன்பாட்டின் புதிய நிகழ்வை துவக்குகிறது Set wdApp = New Word.Application மற்றும் பயன்படுத்தி ஒரு புதிய ஆவணத்தை உருவாக்குகிறது Set wdDoc = .Documents.Add. இது எக்செல் இல் உள்ள வரிசைகளை அடையாளம் காட்டுகிறது, அங்கு அட்டவணைகள் வெற்று செல்களை சரிபார்த்து முடிவடையும் மற்றும் இந்த நிலைகளை மாறிகளில் சேமிக்கிறது. First மற்றும் Second. இதன் மூலம் ஒவ்வொரு அட்டவணையும் எங்கு முடிகிறது மற்றும் தொடங்குகிறது என்பதை ஸ்கிரிப்ட் அறிய அனுமதிக்கிறது. மேக்ரோ பின்னர் வேர்டைப் பயன்படுத்தி அட்டவணைகளை உருவாக்குகிறது .Tables.Add(Range:=wdDoc.Range, NumRows:=2, NumColumns:=lCol) மேலும் இந்த அட்டவணைகளை எக்செல் தரவுடன் நிரப்புகிறது.
ஒவ்வொரு அட்டவணையும் தெளிவாகப் பிரிக்கப்பட்டிருப்பதை உறுதிசெய்ய, ஒவ்வொரு அட்டவணையைப் பயன்படுத்திய பிறகும் ஸ்கிரிப்ட் ஒரு பக்க இடைவெளியைச் செருகும் wdDoc.Characters.Last.InsertBreak Type:=wdPageBreak. தி CreateTable ஒவ்வொரு அட்டவணையையும் உருவாக்க மற்றும் வடிவமைக்க சப்ரூட்டின் மூன்று முறை அழைக்கப்படுகிறது. இந்த சப்ரூட்டீன் தலைப்புகளை வரையறுக்கிறது, வரிசைகள் மற்றும் நெடுவரிசைகளை விரிவுபடுத்துகிறது மற்றும் அட்டவணைகளுக்கு எல்லை பாணிகளைப் பயன்படுத்துகிறது .Rows(1).Range.Font.Bold = True மற்றும் With wdTbl.Borders. இறுதியாக, மேக்ரோ வேர்ட் பயன்பாட்டின் தெரிவுநிலையை உண்மையாக அமைக்கிறது wdApp.Visible = True, உருவாக்கப்பட்ட ஆவணத்தை பயனர் பார்க்க முடியும் என்பதை உறுதிப்படுத்துகிறது. இந்த அணுகுமுறை Excel இலிருந்து பல அட்டவணைகளை ஒரு வேர்ட் ஆவணமாக திறம்பட ஒருங்கிணைத்து, தெளிவு மற்றும் வடிவமைப்பை பராமரிக்கிறது.
பல எக்செல் அட்டவணைகளை ஒரு வார்த்தை ஆவணமாக ஒருங்கிணைத்தல்
இந்த ஸ்கிரிப்ட், எக்செல் இல் VBA ஐப் பயன்படுத்தி, பல டேபிள்களை ஒரு வேர்ட் ஆவணமாக இணைத்து, ஒவ்வொரு டேபிளுக்குப் பிறகும் பக்க இடைவெளிகளுடன் முடிக்கவும்.
Sub ConsolidateTablesInOneDocument()Dim wdApp As New Word.ApplicationDim wdDoc As Word.DocumentDim wdTbl As Word.TableDim xlSht As WorksheetDim lRow As Integer, lCol As IntegerDim r As Integer, c As IntegerDim Blanks As Integer, First As Integer, Second As IntegerlRow = Sheets("Feedback Sheets").Range("A1000").End(xlUp).Row - 2Blanks = 0i = 1Do While i <= lRowSet rRng = Worksheets("Feedback Sheets").Range("A" & i)If IsEmpty(rRng.Value) ThenBlanks = Blanks + 1If Blanks = 1 Then First = iIf Blanks = 2 Then Second = iEnd Ifi = i + 1LoopSet xlSht = ActiveSheet: lCol = 5With wdApp.Visible = TrueSet wdDoc = .Documents.AddCall CreateTable(wdDoc, xlSht, 1, First, lCol)wdDoc.Characters.Last.InsertBreak Type:=wdPageBreakCall CreateTable(wdDoc, xlSht, First + 1, Second, lCol)wdDoc.Characters.Last.InsertBreak Type:=wdPageBreakCall CreateTable(wdDoc, xlSht, Second + 1, lRow, lCol)End WithEnd SubSub CreateTable(wdDoc As Word.Document, xlSht As Worksheet, startRow As Integer, endRow As Integer, lCol As Integer)Dim wdTbl As Word.TableDim r As Integer, c As IntegerSet wdTbl = wdDoc.Tables.Add(Range:=wdDoc.Range, NumRows:=2, NumColumns:=lCol)With wdTbl.Rows(1).Range.Font.Bold = True.Rows(1).HeadingFormat = True.Cell(1, 1).Range.Text = "Header 1"If lCol > 1 Then .Cell(1, 2).Range.Text = "Header 2"If lCol > 2 Then .Cell(1, 3).Range.Text = "Header 3"For r = startRow To endRowIf (r - startRow + 2) > .Rows.Count Then .Rows.AddFor c = 1 To lCol.Cell(r - startRow + 2, c).Range.Text = xlSht.Cells(r, c).TextNext cNext rEnd WithWith wdTbl.Borders.InsideLineStyle = wdLineStyleSingle.OutsideLineStyle = wdLineStyleDoubleEnd WithEnd Sub
எக்செல் டேட்டாவை வேர்டில் VBA உடன் இணைத்தல்
இந்த ஸ்கிரிப்ட், எக்செல் தாளில் இருந்து அட்டவணைகளை ஒரு ஒற்றை வேர்ட் ஆவணமாக ஒன்றிணைக்க VBA ஐப் பயன்படுத்துகிறது, இது சரியான வடிவமைப்பு மற்றும் பக்க முறிவுகளை உறுதி செய்கிறது.
Sub MergeTablesIntoWord()Dim wdApp As New Word.ApplicationDim wdDoc As Word.DocumentDim wdTbl As Word.TableDim xlSht As WorksheetDim lRow As Integer, lCol As IntegerDim r As Integer, c As IntegerDim Blanks As Integer, First As Integer, Second As IntegerlRow = Sheets("Feedback Sheets").Range("A1000").End(xlUp).Row - 2Blanks = 0i = 1Do While i <= lRowSet rRng = Worksheets("Feedback Sheets").Range("A" & i)If IsEmpty(rRng.Value) ThenBlanks = Blanks + 1If Blanks = 1 Then First = iIf Blanks = 2 Then Second = iEnd Ifi = i + 1LoopSet xlSht = ActiveSheet: lCol = 5With wdApp.Visible = TrueSet wdDoc = .Documents.AddSet wdTbl = wdDoc.Tables.Add(Range:=wdDoc.Range, NumRows:=2, NumColumns:=lCol)PopulateTable wdTbl, xlSht, 1, First, lColwdDoc.Characters.Last.InsertBreak Type:=wdPageBreakSet wdTbl = wdDoc.Tables.Add(Range:=wdDoc.Range, NumRows:=2, NumColumns:=lCol)PopulateTable wdTbl, xlSht, First + 1, Second, lColwdDoc.Characters.Last.InsertBreak Type:=wdPageBreakSet wdTbl = wdDoc.Tables.Add(Range:=wdDoc.Range, NumRows:=2, NumColumns:=lCol)PopulateTable wdTbl, xlSht, Second + 1, lRow, lColEnd WithEnd SubSub PopulateTable(wdTbl As Word.Table, xlSht As Worksheet, startRow As Integer, endRow As Integer, lCol As Integer)Dim r As Integer, c As IntegerWith wdTbl.Rows(1).Range.Font.Bold = True.Rows(1).HeadingFormat = True.Cell(1, 1).Range.Text = "Header 1"If lCol > 1 Then .Cell(1, 2).Range.Text = "Header 2"If lCol > 2 Then .Cell(1, 3).Range.Text = "Header 3"For r = startRow To endRowIf (r - startRow + 2) > .Rows.Count Then .Rows.AddFor c = 1 To lCol.Cell(r - startRow + 2, c).Range.Text = xlSht.Cells(r, c).TextNext cNext rEnd WithWith wdTbl.Borders.InsideLineStyle = wdLineStyleSingle.OutsideLineStyle = wdLineStyleDoubleEnd WithEnd Sub
VBA உடன் வேர்டில் அட்டவணைகளை உருவாக்குதல் மற்றும் வடிவமைத்தல்
VBA ஐப் பயன்படுத்தி Excel இலிருந்து Word க்கு தரவு பரிமாற்றத்தை தானியங்குபடுத்தும் போது, அட்டவணைகளை எவ்வாறு திறம்பட நிர்வகிப்பது மற்றும் வடிவமைப்பது என்பதைப் புரிந்துகொள்வது முக்கியம். ஒரு முக்கிய அம்சம், தரவு சரியாக மாற்றப்படுவதை உறுதிசெய்து, கட்டமைப்பு மற்றும் வாசிப்புத்திறன் இரண்டையும் பராமரிக்கிறது. அட்டவணை உருவாக்கம், வடிவமைத்தல் மற்றும் பக்க முறிவுகளைச் செருகுவதைக் கட்டுப்படுத்தும் VBA கட்டளைகளைப் புரிந்துகொள்வது இதற்குத் தேவைப்படுகிறது. உதாரணமாக, கட்டளை Set wdTbl = wdDoc.Tables.Add(Range:=wdDoc.Range, NumRows:=2, NumColumns:=lCol) எக்செல் தரவின் அடிப்படையில் வரிசைகள் மற்றும் நெடுவரிசைகளின் எண்ணிக்கையைக் குறிப்பிடுவதன் மூலம் Word ஆவணத்தில் புதிய அட்டவணையைச் சேர்க்கப் பயன்படுகிறது.
மற்றொரு முக்கியமான உறுப்பு அட்டவணையை வடிவமைப்பது. போன்ற கட்டளைகள் .Rows(1).Range.Font.Bold = True முதல் வரிசையை தடிமனாக மாற்றவும், தலைப்புகளைக் குறிக்கவும் wdTbl.Borders அட்டவணையின் உள் மற்றும் வெளிப்புறக் கோடுகளுக்கு எல்லைப் பாணிகளை அமைக்கப் பயன்படுகிறது. மேலும், ஒவ்வொரு அட்டவணையும் தனித்தனி பக்கத்தில் தோன்றுவதை உறுதிசெய்ய பக்க முறிவுகளைச் செருகுவது அவசியம். wdDoc.Characters.Last.InsertBreak Type:=wdPageBreak. இந்த கட்டளைகள் கூட்டாக இறுதி ஆவணம் நன்கு ஒழுங்கமைக்கப்பட்டு தொழில்ரீதியாக வடிவமைக்கப்படுவதை உறுதி செய்கிறது.
Word மற்றும் Excel க்கான VBA மேக்ரோக்கள் பற்றி அடிக்கடி கேட்கப்படும் கேள்விகள்
- VBA ஐப் பயன்படுத்தி ஒரு புதிய Word பயன்பாட்டை எவ்வாறு தொடங்குவது?
- பயன்படுத்தவும் Set wdApp = New Word.Application வேர்ட் பயன்பாட்டின் புதிய நிகழ்வைத் தொடங்குவதற்கு.
- VBA ஐப் பயன்படுத்தி வேர்ட் ஆவணத்தில் பக்க இடைவெளியை எவ்வாறு செருகுவது?
- உடன் ஒரு பக்க இடைவெளியைச் செருகவும் wdDoc.Characters.Last.InsertBreak Type:=wdPageBreak.
- VBA ஐப் பயன்படுத்தி Word ஆவணத்தில் அட்டவணையை எவ்வாறு சேர்ப்பது?
- பயன்படுத்தி அட்டவணையைச் சேர்க்கவும் wdDoc.Tables.Add(Range:=wdDoc.Range, NumRows:=2, NumColumns:=lCol).
- அட்டவணையின் முதல் வரிசையை தலைப்பாக எப்படி வடிவமைப்பது?
- முதல் வரிசையை தலைப்பாக அமைக்கவும் .Rows(1).HeadingFormat = True மற்றும் அதை பயன்படுத்தி தைரியமாக செய்ய .Rows(1).Range.Font.Bold = True.
- VBA ஐப் பயன்படுத்தி Word இல் அட்டவணைக்கான எல்லைகளை எவ்வாறு அமைப்பது?
- உடன் எல்லைகளை அமைக்கவும் wdTbl.Borders, உள்ளே மற்றும் வெளிப்புறக் கோடுகளுக்கான பாணிகளைக் குறிப்பிடுதல்.
- VBA இல் உள்ள பயனருக்கு வேர்ட் அப்ளிகேஷன் எப்படி தெரியும்?
- உடன் தெரிவுநிலையை அமைக்கவும் wdApp.Visible = True.
- தற்போதைய வரிசை தற்போதைய வரிசை எண்ணிக்கையை மீறினால், அட்டவணையில் புதிய வரிசையைச் சேர்க்க என்ன கட்டளை பயன்படுத்தப்படுகிறது?
- உடன் புதிய வரிசையைச் சேர்க்கவும் If (r - startRow + 2) > .Rows.Count Then .Rows.Add.
- VBA ஐப் பயன்படுத்தி Word இல் புதிய ஆவணத்தை எவ்வாறு உருவாக்குவது?
- உடன் புதிய ஆவணத்தை உருவாக்கவும் Set wdDoc = .Documents.Add.
இறுதி எண்ணங்கள்
VBA ஐப் பயன்படுத்தி பல எக்செல் அட்டவணைகளை ஒரே வேர்ட் ஆவணமாக இணைப்பது தரவு பரிமாற்றம் மற்றும் வடிவமைப்பின் செயல்முறையை ஒழுங்குபடுத்துகிறது. அட்டவணை உருவாக்கம், வடிவமைத்தல் மற்றும் பக்க முறிவுகளை தானியங்குபடுத்துவதன் மூலம், இறுதி ஆவணம் நன்கு ஒழுங்கமைக்கப்பட்டு தொழில் ரீதியாக வழங்கப்படுவதை மேக்ரோ உறுதி செய்கிறது. இந்த அணுகுமுறை நேரத்தைச் சேமிக்கிறது மற்றும் பிழைகளின் அபாயத்தைக் குறைக்கிறது, இது பல்வேறு தளங்களில் தரவை நிர்வகிப்பதற்கும் வழங்குவதற்கும் ஒரு திறமையான தீர்வாக அமைகிறது.