VBA100本ノック 65本目:固定長テキスト出力
フォーマット(左詰め文字、右詰め数値)に従い、固定長テキストを出力する問題です。
ツイートでの見やすさを考慮して、ブック・シート指定等を適宜省略しています。
出題
固定長データの出力です。
「フォーマット」シートに従い、2行目以降をテキスト出力してください。
文字形態は、N:右詰め0埋め、C:左詰め半角スペース埋め。
項目間区切りなしで連続で出力
※シートは任意
※本題ではないので出力ファイル及び文字コードは任意
https://excel-ubara.com/vba100sample/VBA100_65.xlsm
https://excel-ubara.com/vba100sample/VBA100_65.zip
VBA作成タイム
この下に頂いた回答へのリンクと解説を掲載しています。
途中まででも良いので、できるだけ自分でVBAを書いてみましょう。
他の人の回答および解説を見て、書いたVBAを見直してみましょう。
頂いた回答
解説
でも全く不要という事もないので、一度は経験しておいた方が良いだろうという事で出題しました。
DictionaryとFileSystemObjectを参照設定して使っています。
Sub VBA100_65_01()
Dim ws As Worksheet, rng As Range
Dim objFso As New FileSystemObject
Dim objTS As TextStream, sFile As String
Set ws = ActiveSheet
Set rng = ws.Range("A1").CurrentRegion
sFile = ws.Parent.Path & "\data.txt"
Set objTS = objFso.CreateTextFile(sFile, True)
Dim dic As Dictionary, i As Long, j As Long, ary
Set dic = getFormat(Worksheets("フォーマット"))
For i = 2 To rng.Rows.Count
ReDim ary(rng.Columns.Count)
For j = 1 To rng.Columns.Count
ary(j) = getFixedString(dic, rng(1, j).Value, rng(i, j).Value)
Next
objTS.WriteLine Join(ary, "")
Next
objTS.Close
Set dic = Nothing: Set objTS = Nothing: Set objFso = Nothing
ThisWorkbook.FollowHyperlink sFile
End Sub
Function getFormat(ByVal ws As Worksheet) As Dictionary
Dim dic As New Dictionary, i As Long
For i = 2 To ws.Cells(ws.Rows.Count, 1).End(xlUp).Row
dic(ws.Cells(i, 1).Value) = Array(ws.Cells(i, 2).Value, ws.Cells(i, 3).Value)
Next
Set getFormat = dic
End Function
Function getFixedString(ByVal dic As Object, ByVal aFormat, ByVal aIn) As String
If Not dic.Exists(aFormat) Then Exit Function '未登録列は空で返しスキップ
Dim sForm As String: sForm = dic(aFormat)(0)
Dim iLen As Integer: iLen = dic(aFormat)(1)
If UCase(sForm) = "N" Then
getFixedString = Right(String(iLen, "0") & aIn, iLen)
Else
getFixedString = Left(aIn & Space(iLen), iLen)
End If
End Function
処理最後で作成したテキストをメモ帳(既定なら)で開いています。
補足はありません。
補足
サイト内関連ページ
同じテーマ「VBA100本ノック」の記事
66本目:全サブフォルダからファイルを探す
新着記事NEW ・・・新着記事一覧を見る
TRIMRANGE関数(セル範囲をトリム:端の空白セルを除外)|エクセル入門(2024-08-30)
正規表現関数(REGEXTEST,REGEXREPLACE,REGEXEXTRACT)|エクセル入門(2024-07-02)
エクセルが起動しない、Excelが立ち上がらない|エクセル雑感(2024-04-11)
ブール型(Boolean)のis変数・フラグについて|VBA技術解説(2024-04-05)
テキストの内容によって図形を削除する|VBA技術解説(2024-04-02)
ExcelマクロVBA入門目次|エクセルの神髄(2024-03-20)
VBA10大躓きポイント(初心者が躓きやすいポイント)|VBA技術解説(2024-03-05)
テンキーのスクリーンキーボード作成|ユーザーフォーム入門(2024-02-26)
無効な前方参照か、コンパイルされていない種類への参照です。|エクセル雑感(2024-02-17)
初級脱出10問パック|VBA練習問題(2024-01-24)
アクセスランキング ・・・ ランキング一覧を見る
1.最終行の取得(End,Rows.Count)|VBA入門
2.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.繰り返し処理(For Next)|VBA入門
5.RangeとCellsの使い方|VBA入門
6.ブックを閉じる・保存(Close,Save,SaveAs)|VBA入門
7.セルのクリア(Clear,ClearContents)|VBA入門
8.メッセージボックス(MsgBox関数)|VBA入門
9.条件分岐(Select Case)|VBA入門
10.マクロとは?VBAとは?VBAでできること|VBA入門
- ホーム
- マクロVBA入門編
- VBA100本ノック
- 65本目:固定長テキスト出力
このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。