
No.5ベストアンサー
- 回答日時:
No.1です。
> 2行目以降で、改行毎に横のセルに並べたいと思っておりました。
それならセルの位置を決める変数をもち、改行コードを見つけるたびにこの変数が指す先に文字列をコピーして変数をカウントアップする、、、という処理を文字列全体の最後尾まで処理を繰り返せばよいです。
ときうことで「関数を考える」のではなく「処置手順を(日本語で)考える」ことが大切です。
Excelが提供する各種関数にまだ詳しくないうちは、無理に難しい関数を使うのではなく、ちょっと泥臭くても思いつく素直な考え方の「処理手順」を実装することを優先されるとよいと思います。
で。後々、便利ご自身が考えたそうなExcel関数を知った際に「これを使うとこういう処理手順となりもっと単純になるな」と学ぶことが大切と考えます。
参考まで。
たびたびのご回答ありがとうございます。
そうですね、皆さんの回答を元にさらに調べたところ、わたしのやりたかった事が関数以外で解決することがわかりました。
Excelの処理でわからないことは関数で解決!と安直に考えずに、もっと柔軟に考えることが必要ですね。とても参考になりました、ありがとうございます。
No.7
- 回答日時:
数式でもなくマクロでもなく、となると区切り位置機能でもできます。
データタブ→区切り位置→○カンマやタブなどの区切り文字によって~を選択
→次へ→区切り文字の「その他」にチェックを入れ横のボックス内で「Ctrl+J」を押す(見た目は何も表示されない)
→完了
一旦質問したのですから、どのような方法で解決したか回答者に報告するのが礼儀ですし、タイトルなどで検索した方が「で、数式以外ってどんな方法!?」となることもあるでしょうからきちんと書いていただく方がいいかと思います。
ご回答ありがとうございます。
礼儀を知らずご迷惑をお掛けして大変申し訳ございませんでした。
この質問システムを始めて使用したので、要領をわからずに使用していました。慣れないシステムは、他人様に迷惑をお掛けすることになるので、わたしのような無礼者は決して利用するべきではありませんでした。申し訳ございませんでした。
しかし、chonami様のお陰でひとつ賢くなれたと思います、大変感謝しております。今後も礼儀をわきまえた立派な人間になれるよう精進致します。
わたしのやりたかったことは、区切り位置の使用で解決いたしました。
この度は大変お世話になりました。
どうもありがとうございます。
No.6
- 回答日時:
>関数以外で解決することがわかりました。
配列にすればよいのでは?
全部でも、一部でも取り出すことは可能です。
Test2は、ホームタブ-編集-文字の割り付けに似てはいますが、機能的には違います。以下は、A1 にデータがあった場合とします。
Sub Test1()
Dim arBuf, i As Long
arBuf = Split(Range("A1").Value, vbLf)
i = UBound(arBuf)
Range("B1").Resize(, i + 1).Value = arBuf 'B1から右方向へ
End Sub
Sub Test2()
Dim arBuf, i As Long
arBuf = Split(Range("A1").Value, vbLf)
i = UBound(arBuf)
Range("B1").Resize(i + 1).Value = _
WorksheetFunction.Transpose(arBuf) 'B1から下方向へ
End Sub
No.4
- 回答日時:
チョイと気になったもので・・・
「急いでいます!!」なら尚更のことですが、別の「Excel(エクセル)」というカテゴリの専用部屋で質問されることをお奨めします。
ご解答ありがとうございます。急いでいて、かつ、教えて!gooを使用するのが今回が初めてだったので要領を理解しておりませんでした。次回からは注意致します。
No.3
- 回答日時:
セル A1 内の文字列が7、8行毎に改行されている場合しかためしていないけど、次式が貴方のお眼鏡に適うかどうか試してみてください。
=TRIM(MID(SUBSTITUTE($A1,CHAR(10),REPT(" ",500)),1+(COLUMN(A1)-1)*500,250))
セル B1 に上式を入力して、此れを右方にズズーッとオートフィル

ご回答ありがとうございます。複雑な関数ですね、試してみます。
それにしても、こんな複雑な関数が思い付いてしまうmike_gさん、尊敬します。
No.1
- 回答日時:
> excelのセルの中で、改行されている文字列の複数行目の文字列
というのは具体的に何行目を取り出したいのでしょう?
例えば3行目だとすると、対象セルの内容に対し。。。
(1) 文字列検索で改行コードを検索する。
(2) 改行コードが無かったらエラー?(セル内に1行しかない)
(3) 改行コードがあったらその次の文字以降を対象に再度改行コードを検索
(4) 改行コードが無かったらエラー?(セル内に2行しかない)
(5) 改行コードがあったらその次の文字以降を対象に再度改行コードを検索
(6) 改行コードが無かったら(5)の検索開始位置から行末までの文字列を移動先のセルへコピーする(または移動する)
(7) 改行コードがあったら(5)の検索開始位置から改行コードの前の文字までの文字列を移動先のセルへコピーする(または移動する)
という感じでしょう。
改行検索はInStr関数()で出来ます。
参考まで。
ご回答ありがとうございます。質問のしかたが悪くて申し訳ありません。
2行目以降で、改行毎に横のセルに並べたいと思っておりました。
試してみます、ありがとうございます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
プロが教えるわが家の防犯対策術!
ホームセキュリティのプロが、家庭の防犯対策を真剣に考える 2組のご夫婦へ実際の防犯対策術をご紹介!どうすれば家と家族を守れるのかを教えます!
-
エクセルでセル内改行の1行目だけ抜き出す関数は?
Excel(エクセル)
-
エクセルの関数にてセル内改行→3行目を抜きたい
その他(Microsoft Office)
-
Excelセル内の改行を含む文字列の1行目抽出
その他(Microsoft Office)
-
4
セル内で改行された文字列を1行ずつ他のセルに移す
Excel(エクセル)
-
5
1つのセルにまとまっている情報を複数行に分けたい
Excel(エクセル)
-
6
エラーコード 70 「書き込みできません」について
Visual Basic(VBA)
-
7
【エクセル】セル最後にある無駄改行を検索・削除したい
Excel(エクセル)
-
8
エクセルの改行時、2行目の頭にスペースを入れる方法
その他(パソコン・スマホ・電化製品)
-
9
検索の画面がでなくなってしまいました。(EXCEL)
Excel(エクセル)
-
10
【エクセル】区切り文字が含まれるデータを縦に展開する方法
Excel(エクセル)
-
11
あるセルに特定の文字列を打つと、他のセルに決められた文字が自動入力するように
Excel(エクセル)
-
12
エクセルでリンクが更新されない
その他(ソフトウェア)
-
13
同一セルに日時があるものを日付と時間に分ける方法
その他(ソフトウェア)
-
14
【Excel】特定の文字から文字までの間を削除する
Excel(エクセル)
-
15
'Range'メソッドは失敗しました
Excel(エクセル)
-
16
空白を0とみなす関数
Excel(エクセル)
-
17
エクセルでセルのデータがカタカナかどうか調べたい
Excel(エクセル)
-
18
Outlookで2週間以上前のメールが表示されない
Outlook(アウトルック)
関連するカテゴリからQ&Aを探す
このQ&Aを見た人がよく見るQ&A
人気Q&Aランキング
-
4
CSVファイルでテキストの改行の...
-
5
短歌が1行で収まらない場合、...
-
6
excelで勝手に改行されます
-
7
バッチで指定ファイルの文末に...
-
8
ベタ打ちってなんですか?
-
9
EXCELで"-"で勝手に自動改行し...
-
10
棒グラフ 横軸の縦書き2列にし...
-
11
PDFの改行URLを有効にす...
-
12
wordで均等割り付けをするとき...
-
13
VBA フォームのテキストボック...
-
14
AutoCADのダイナミック文字記入...
-
15
エクセルで字下げ
-
16
Excel、VBA、1行中複数セルに...
-
17
Accessにインポートしようとす...
-
18
サクラエディタは複数行に渡る...
-
19
パワーポイントのリンク管理に...
-
20
teratermのコマンド入力文字数...
おすすめ情報
公式facebook
公式twitter