
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
こんばんは。
数式では、このようになりましたが、1個しか出てきません。横にドラッグコピーします。
=MOD(LARGE(INDEX((LEN($A1)-LEN(SUBSTITUTE($A1,COLUMN($A$1:$J$1)-1,"")))+COLUMN($A$1:$J$1)/10,,),COLUMN(A$1)),1)*10-1
多い順からセル1つに1つずつでますが、横にコピーすると、全部が出てきてしまいます。
以下のA1の場合は、4,5,3 となってしまいます。
VBAでは、このようにすればできるはずです。
使い方は、簡単。
A1:123451243456
A2:5678914758
A3:3692400837
=CountNums(A1) ->4 (最大の数しか出ません。)
=CountNums(A2) ->578
=CountNums(A3) ->03
'//標準モジュール
Function CountNums(ByVal セル As Variant)
Dim strNums As String
Dim textLen As Long
Dim ret As Variant, arbuf(0 To 9) As Long
Dim i As Long, buf As Variant
Dim cMax As Long
Application.Volatile '再計算を繰り返すようなら、先頭に「'」シングルコーテーションを入れてください。
If Not IsNumeric(セル.Text) Then CountNums = ""
strNums = セル.Value2
textLen = Len(strNums)
buf = "": ret = 0
For i = 0 To 9
ret = textLen - Len(Replace(strNums, i, ""))
If ret > 0 Then
arbuf(i) = ret
If cMax < ret Then cMax = ret '最大数をカウント
End If
ret = ""
Next
For i = 0 To 9
If arbuf(i) = cMax Then
buf = buf & i
End If
Next
CountNums = buf
End Function
No.1
- 回答日時:
こんばんは!
VBAになりますが、一例です。
1行目は項目行でA列2行目以降にデータがあるとし、B列に表示するとします。
Sub Sample1()
Dim i As Long, k As Long, c As Range
Dim myMax As Long, myStr As String
For i = 2 To Cells(Rows.Count, "A").End(xlUp).Row
For k = 1 To Len(Cells(i, "A"))
Set c = Range("D:D").Find(what:=Mid(Cells(i, "A"), k, 1), LookIn:=xlValues, lookat:=xlWhole)
If Not c Is Nothing Then
With c.Offset(, 1)
.Value = .Value + 1
End With
Else
With Cells(Rows.Count, "D").End(xlUp).Offset(1)
.Value = Mid(Cells(i, "A"), k, 1)
.Offset(, 1) = 1
End With
End If
Next k
myMax = WorksheetFunction.Max(Range("E:E"))
For k = 2 To Cells(Rows.Count, "D").End(xlUp).Row
If Cells(k, "E") = myMax Then
myStr = myStr & Cells(k, "D")
End If
Next k
Cells(i, "B") = myStr
myStr = ""
Range("D:E").ClearContents
Next i
End Sub
※ 作業用の列として、D・E列を使っていますので、
D・E列にはなにもデータがないようにしておいてください。
※ 質問文は数値データで、「0」がありませんが、
万一「0」が最大個数で、最初に出現する場合は
「0」が表示されないかもしれません。m(_ _)m
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) エクセルの数式で教えてください。 1 2022/10/25 09:26
- Excel(エクセル) エクセルの数式で教えてください。 1 2023/02/15 08:30
- Excel(エクセル) 関数EXACT(文字列,文字列)とexcelVBA 3 2022/04/14 15:07
- Excel(エクセル) エクセルの数式で教えてください。 1 2023/04/21 08:59
- Excel(エクセル) エクセルで#以降の文字を取得したい 1 2022/03/28 13:14
- Excel(エクセル) Excelで数式をそのままコピーしたい どうすればいいですか? 4 2022/09/16 02:16
- Excel(エクセル) エクセルの条件付き書式で*を使いたい 4 2022/05/13 16:49
- Excel(エクセル) Indirect関数について、Formulatextで抽出した数式を参照したい。 1 2022/12/15 11:16
- Excel(エクセル) 条件に合った数値の合計を表示させたい関数と条件指定の方法 3 2023/05/13 16:07
- Excel(エクセル) excelで可視セルのみ置換 3 2022/08/04 11:02
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルの関数について
-
エクセルのリストについて
-
【マクロ】元データと同じお客...
-
エクセルの複雑なシフト表から...
-
【画像あり】オートフィルター...
-
【マクロ】【相談】Excelブック...
-
【マクロ】変数に入れるコード...
-
【マクロ】別ファイルへマクロ...
-
エクセルシートの見出しの文字...
-
【マクロ】数式を入力したい。...
-
Office2021のエクセルで米国株...
-
【マクロ】実行時エラー '424':...
-
他のシートの検索
-
【マクロ】左のブックと右のブ...
-
Amazonでマイクロソフトオフィ...
-
エクセルのVBAで集計をしたい
-
エクセル GROUPBY関数について...
-
【マクロ】オートフィルターの...
-
【マクロ】列を折りたたみ非表...
-
ページが変なふうに切れる
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
9月17日でサービス終了らし...
-
エクセル
-
【マクロ】WEBシステムから保存...
-
エクセルの循環参照、?
-
エクセル ドロップダウンリスト...
-
エクセルのdatedif関数を使って...
-
特定のセルだけ結果がおかしい...
-
【マクロ】A列にある、日付(本...
-
【マクロ】EXCELで読込したCSV...
-
【マクロ】アクティブセルの時...
-
【エクセル】期限アラートについて
-
iPhoneのExcelアプリで、別のシ...
-
【関数】同じ関数なのに、エラ...
-
Excelの新しい空白のブックを開...
-
【マクロ】3行に上から下に並...
-
【マクロ】宣言は、何のために...
-
VBA チェックボックスをオーバ...
-
Excelについての質問です 並べ...
-
【マクロ】アクティブセルの2...
-
【関数】不規則な文章から●●-●●...
おすすめ情報