
下記↓のようなデータがあります。
=========
A B C
1 りんご なし みかん
2 なし
3 みかん りんご
=========
これを↓下記のようなデータにかえたいです。
=========
A
1 りんご,なし,みかん
2 なし
3 みかん,りんご
=========
元々後者のデータだったのですが、
作業のため区切り位置で前者のデータに加工しました。
が、元に戻す必要が出てきました・・・。
&を使ってやる方法だと
りんご,なし,みかん
なし,,
みかん,りんご,
となってしまうし、うまいやり方が思いつきません。
IF関数を使って、ブランクセルの場合は「,」をつけない、とかやれば
できそうな気もしますが、勉強不足でどういう関数を書いたらいいか分かりません・・・。
エクセルにお詳しい方、ご教授いただければ幸いです。
No.9
- 回答日時:
二つ考えてみました。
=CONCATENATE(A1,IF(B1="","","," & B1),IF(C1="","",","&C1))
=CHOOSE(COUNTA(A1:C1),A1,A1&"," &B1,A1&","&B1&","&C1)
3個以上になれば、ズラズラと長くする必要がありますが、上の方がスマートと感じます。
ふたつも考えてくださってありがとうございます!
関数をネストするのが苦手で・・
CONCATENATEって関数はじめてみました。勉強します。
回答がたくさん寄せられているのに気付かず
結局手作業でやってしまったのですが
次回同じ作業が発生した時にはぜひ試してみたいと思います。
ありがとうございました。
No.7
- 回答日時:
関数でやると式が長くなる。
VBAでCSVを「扱うとき、しょっちゅう出てくる課題なのでユ、ーザー定義関数を使いやってみる。
例データ
A2:C4の範囲
りんごなしみかん
りんご
りんごみかん
ーー
標準モジュールに
Function CSVC(a)
Dim cl
s = ""
For Each cl In a
If cl <> "" Then
s = s & cl & ","
End If
Next
CSVC = Left(s, Len(s) - 1) '最後の,を削除
End Function
--
この関数の使い方
シートの
E2セルに =csvc(A2:D2) D2はどの列まででも良いが本例ではD列までありえるとした場合
下方向に式を複写する。
結果
E列
りんご,なし,みかん
りんご
りんご,みかん
E列が結果です
No.6
- 回答日時:
こんばんは!
VBAになってしまいますが・・・
一例です。
Sheet1のデータをSheet2に表示するようにしてみました。
※ Sheet1のデータは1行目からあるとします。
画面左下のSheet1のSheet見出し上で右クリック → コードの表示 → VBE画面がでますので
↓のコードをコピー&ペーストしてマクロを実行してみてください。
(Alt+F8キー → マクロ → マクロ実行です)
Sub test() 'この行から
Dim i, j As Long
Dim str As String
Dim ws As Worksheet
Set ws = Worksheets(2)
For i = 1 To Cells(Rows.Count, 1).End(xlUp).Row
For j = 1 To Cells(i, Columns.Count).End(xlToLeft).Column
str = str & Cells(i, j) & ","
Next j
ws.Cells(i, 1) = Left(str, Len(str) - 1)
str = ""
Next i
ws.Columns(1).AutoFit
End Sub 'この行まで
以上、参考になれば良いのですが、
ご希望の方法でなかったらごめんなさいね。m(_ _)m
マクロまで書いてくださってありがとうございます!
回答がたくさん寄せられているのに気付かず
結局手作業でやってしまったのですが
次回同じ作業が発生した時にはぜひ試してみたいと思います。
ありがとうございました。
No.2
- 回答日時:
A列を挿入して A1セルに
=SUBSTITUTE(TRIM(CONCATENATE(B1," ",C1," ",D1," ",E1," ",F1," ",G1," ",H1," ",I1," ",J1," ",K1," ",L1," ",M1," ",N1," ",O1))," ",",")
下へオートフィル
A列をコピーして
メモ帳に貼り付け
または、形式を選択して貼り付け 値の貼り付け
No.1
- 回答日時:
一旦、csv形式のファイルにして保存し、・・・
=========
A B C
1 りんご なし みかん
2 なし
3 みかん りんご
=========
この Excelシートが、
=========
りんご,なし,みかん
なし
みかん,りんご
=========
というファイルになります。
そのcsv形式のファイルの一行を1セルに読み込む方法ではダメ(面倒)ですか?
ご回答ありがとうございます!
その作業はぜんぜん面倒ではないのですが、
やりかたが悪いのか、教えていただいた通りになりません。
わたしがやると・・・
csv形式にして保存
↓
エクセル(2007)で開いても同じようにセルはわかれたまま・・・
エクセルで開いたからくっついてくれないのかな?
と思ってメモ帳やワードパッドで開いてみましたが
今度は
なし,,
みかん,りんご,
という感じで後ろに,がついてしまいます。
なにか間違ってますでしょうか?
あるいは
作業列を足したり、何ステップか踏んだりしてもいいので
ほかのやり方はありますか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
エクセルで「データ」の「区切り位置」について
その他(Microsoft Office)
-
有無、要否、賛否、是非、可否、当否…これらの言葉について
その他(教育・科学・学問)
-
エクセル:桁区切り「カンマ」でセルが分割されて貼り付けされてしまう
Excel(エクセル)
-
-
4
エクセルのグラフの色を統一するやり方を教えてください!
Excel(エクセル)
-
5
EXCELで2列を参照し、重複するものを横に並べたい
Excel(エクセル)
-
6
カンマ区切り形式ではなく、セミコロン区切り形式のCSVファイルを作りた
その他(ソフトウェア)
-
7
exeファイルの中身を見ることは可能ですか?
フリーソフト
-
8
セル入力文字が、「右のセルにはみ出す場合と」「はみ出さない場合」の違い
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excelで隣のセルと同じ内容に列...
-
エクセルに入力された日付「S40...
-
【エクセル】区切り位置で分割...
-
SUMPRODUCT関数 行が増えても...
-
EXCELデータのCSV変換の限界
-
エクセル日付 文字列の関数がエ...
-
correl関数の範囲指定
-
更新前と更新後の差分をVBAを使...
-
ピボットテーブル 0個の行を...
-
Excel関数で、範囲内の最後のセ...
-
値の入っているセルのうち、一...
-
Excel関数:「0」を除いた標準...
-
エクセルVBAを使ってセルに日付...
-
離れたエリアでVLookupを使いたい
-
エクセル 8ケタの数字から日数...
-
Excelで順番を逆に
-
ExcelVBAのご質問(sumifs)
-
Excelのオートコンプリートにつ...
-
グラフにてX軸、Y軸をそれぞれ...
-
EXCELで2つの数値のうち大きい...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excelで隣のセルと同じ内容に列...
-
【エクセル】区切り位置で分割...
-
更新前と更新後の差分をVBAを使...
-
値の入っているセルのうち、一...
-
Excel関数:「0」を除いた標準...
-
エクセルに入力された日付「S40...
-
エクセル、正数のみの集計[(負...
-
SUMIFで数値が入力されているセ...
-
Excelで複数列かつ複数行分の一...
-
ピボットテーブル 0個の行を...
-
correl関数の範囲指定
-
【Excel】歯抜けデータの集約
-
複数の候補列から、検索値と一...
-
Excel関数で、範囲内の最後のセ...
-
エクセル 8ケタの数字から日数...
-
EXCEL 階段状のグラフ
-
あるexcel表からチェックボック...
-
エクセルで何種類のデータがあ...
-
Excelで順番を逆に
-
エクセル 別のファイルにデータ...
おすすめ情報