No.1
- 回答日時:
ずばり以下のとおりです。
短時間で制作の為、変数などへんてこで分かり難いかもしれませんが。適当に解析してねー
Dim i, j, kk, sub_K, Ssub_K, k(100) As Integer
Dim moji As String
moji = Range("b4").Value
j = Len(moji)
kk = 1
For i = 0 To j
sub_K = InStr(i + 1, moji, Chr(10))
If sub_K = 0 Then i = j: k(kk) = j - Ssub_K: Exit For Else i = sub_K
k(kk) = (sub_K - Ssub_K) - 1
Ssub_K = sub_K
kk = kk + 1
Next i
For i = 1 To kk
MsgBox k(i)
Next i
No.2ベストアンサー
- 回答日時:
こんな書き方もあるということで・・・
対象セルを1つ選択して下記マクロを実行します。
Sub MojisuCount()
Dim moji As String '選択セルの内容
Dim rw As Integer '行カウンタ
Dim pot As Integer 'Instrで調べた改行コードの位置
moji = Selection & vbLf '選択セルの文字の最後に改行を付加(判定を不要にする)
pot = InStr(moji, vbLf) '改行コードの位置は?
While pot > 0 'なくなるまで続ける
rw = rw + 1 '行を進める
MsgBox rw & "行目は " & pot - 1 & " 文字です"
moji = Mid(moji, pot + 1) '改行文字の次からを新たな検索対象にする
pot = InStr(moji, vbLf) '改行コードの位置は?
Wend
End Sub
この回答へのお礼
お礼日時:2001/08/05 15:03
すばらしくうまく動いてくれました。
感激です。
あなた様の作ってくださるマクロは、ものすごく見やすいです!!!
コメントも書いていただいて、本当に感謝感激です。
これからもお世話してください。
ありがとうございました。
No.3
- 回答日時:
Splitを使うと簡単になります。
Splitは、指定した文字で、文字列を区分けして、配列に入れてくれます。
こんな感じです。
Dim vTerm As Variant
Dim sOrg As String
sOrg = ThisWorkbook.Worksheets(1).Cells(1, 1).Value
vTerm = Split(sOrg, vbLf)
If UBound(vTerm) >= 0 Then
MsgBox (UBound(vTerm) + 1) & "行データがあります。"
Else
MsgBox "データは入っていません。"
End If
For i = 0 To UBound(vTerm)
MsgBox (i + 1) & "行目の文字数は、" & Len(vTerm(i)) & "です。"
Next
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VBAのコマンドボタンの文字列の...
-
ソースコードの1行が長いとき...
-
C++でのCRLFについて
-
選択したセルでダブルクリック...
-
エスケープ文字の復帰(¥r)と...
-
エクセルVBA 文字列領域が不足...
-
ラベル(スタティックテキスト)...
-
VBでcsv読込TextFieldParser...
-
vbsで2文字以上の空白を改行に...
-
ExcelVBAでメールを作成してメ...
-
texのchapterが改行される
-
改行コード(CR/LF)の設...
-
C++で空Enterの入力を判...
-
VBA テキストボックスの行数取得
-
改行について
-
ファイルから読み取った改行文...
-
JavaDoc コメントの改行について
-
textareaに改行を入れても、CSV...
-
awkで改行を除いて文字列を抜き...
-
VBAでCSVをExcelに取り込む時に...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBAのコマンドボタンの文字列の...
-
ソースコードの1行が長いとき...
-
エスケープ文字の復帰(¥r)と...
-
COBOLの改行
-
C++で空Enterの入力を判...
-
C# DataGridViewのセルを改行禁...
-
改行について
-
Excel VBAからBeckyを起動して...
-
ExcelVBAでメールを作成してメ...
-
テキストファイルから改行コー...
-
最終行の改行について
-
グレープシティのSPREAD...
-
JavaDoc コメントの改行について
-
コンボボックスの項目中に改行を
-
エクセルVBA 文字列領域が不足...
-
JavaMail,本文中の改行について
-
ファイルから読み取った改行文...
-
【VBA】エクセルで最後の不要な...
-
JAVA Spring 改行コードを含む...
-
改行コードが半角スペースにな...
おすすめ情報