Подтвердить что ты не робот

Записывать особые символы в строке

Каков самый простой способ подсчета количества вхождений определенного символа в строку?

то есть. Мне нужно написать функцию countTheCharacters(), чтобы

str="the little red hen"
count=countTheCharacters(str,"e") 'count should equal 4
count=countTheCharacters(str,"t") 'count should equal 3
4b9b3361

Ответ 1

Самое простое - просто пропустить символы в строке:

Public Function CountCharacter(ByVal value As String, ByVal ch As Char) As Integer
  Dim cnt As Integer = 0
  For Each c As Char In value
    If c = ch Then 
      cnt += 1
    End If
  Next
  Return cnt
End Function

Использование:

count = CountCharacter(str, "e"C)

Другой подход, который почти так же эффективен и дает более короткий код, - использовать методы расширения LINQ:

Public Function CountCharacter(ByVal value As String, ByVal ch As Char) As Integer
  Return value.Count(Function(c As Char) c = ch)
End Function

Ответ 2

Это простой способ

text="the little red hen"
count = text.Split("e").Length -1 ' Equals 4
count = text.Split("t").Length -1 ' Equals 3

Ответ 3

Вы можете попробовать это

Dim occurCount As Integer = Len(testStr) - Len(testStr.Replace(testCharStr, ""))

Ответ 4

Вот простая версия.

text.count(function(x) x = "a")

Вышеупомянутое даст вам число a в строке. Если вы хотите игнорировать случай:

text.count(function(x) Ucase(x) = "A")

Или, если вы просто хотите подсчитать буквы:

text.count(function(x) Char.IsLetter(x) = True)

Сделайте снимок!

Ответ 5

Или (в VB.NET):

Function InstanceCount(ByVal StringToSearch As String,
                       ByVal StringToFind As String) As Long
    If Len(StringToFind) Then
        InstanceCount = UBound(Split(StringToSearch, StringToFind))
    End If
End Function

Ответ 6

Преобразование Ujjwal Manandhar кода в VB.NET следующим образом:

Dim a As String = "this is test"
Dim pattern As String = "t"
Dim ex As New System.Text.RegularExpressions.Regex(pattern)
Dim m As System.Text.RegularExpressions.MatchCollection
m = ex.Matches(a)
MsgBox(m.Count.ToString())

Ответ 7

Спасибо, @guffa. Возможность сделать это в одной строке или даже в более длинном заявлении в .NET очень удобна. Этот пример VB.NET подсчитывает количество символов LineFeed:

Dim j As Integer = MyString.Count(Function(c As Char) c = vbLf)

j возвращает число LineFeeds в MyString.

Ответ 8

Public Function CountOccurrences(ByVal StToSerach As String, ByVal StToLookFor As String) As Int32

    Dim iPos = -1
    Dim iFound = 0
    Do
        iPos = StToSerach.IndexOf(StToLookFor, iPos + 1)
        If iPos <> -1 Then
            iFound += 1
        End If<br/>
    Loop Until iPos = -1
    Return iFound
End Function

Использование кода:

Dim iCountTimes As Integer = CountOccurrences("Can I call you now?", "a")

Также вы можете использовать его как расширение:

<Extension()> _
Public Function CountOccurrences(ByVal StToSerach As String, ByVal StToLookFor As String) As Int32
    Dim iPos = -1
    Dim iFound = 0
    Do
        iPos = StToSerach.IndexOf(StToLookFor, iPos + 1)
        If iPos <> -1 Then
            iFound += 1
        End If
    Loop Until iPos = -1
    Return iFound
End Function

Использование кода:

Dim iCountTimes2 As Integer = "Can I call you now?".CountOccurrences("a")

Ответ 9

Public Class VOWELS

    Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
        Dim str1, s, c As String
        Dim i, l As Integer
        str1 = TextBox1.Text
        l = Len(str1)
        c = 0
        i = 0
        Dim intloopIndex As Integer
        For intloopIndex = 1 To l
            s = Mid(str1, intloopIndex, 1)
            If (s = "A" Or s = "a" Or s = "E" Or s = "e" Or s = "I" Or s = "i" Or s = "O" Or s = "o" Or s = "U" Or s = "u") Then
                c = c + 1
            End If
        Next
        MsgBox("No of Vowels: " + c.ToString)
    End Sub
End Class

Ответ 10

Когда я нашел это решение, я искал что-то немного другое, поскольку строка, которую я хотел считать, была длиннее одного символа, поэтому я придумал это решение:

    Public Shared Function StrCounter(str As String, CountStr As String) As Integer
        Dim Ctr As Integer = 0
        Dim Ptr As Integer = 1
        While InStr(Ptr, str, CountStr) > 0
            Ptr = InStr(Ptr, str, CountStr) + Len(CountStr)
            Ctr += 1
        End While
        Return Ctr
    End Function

Ответ 11

Я думаю, что это было бы самым простым:

Public Function CountCharacter(ByVal value As String, ByVal ch As Char) As Integer
  Return len(value) - len(replace(value, ch, ""))
End Function

Ответ 12

Другая возможность - работать с Split:

Dim tmp() As String
tmp = Split(Expression, Delimiter)
Dim count As Integer = tmp.Length - 1

Ответ 13

Я предлагаю вам сделать вот так:

String.Replace("e", "").Count
String.Replace("t", "").Count

Вы также можете использовать .Split("e").Count - 1 или .Split("t").Count - 1 respetivelly, но он дает неправильные значения, если вы, например, имеете e или t в начале String

Ответ 14

Использование регулярных выражений...

Public Function CountCharacter(ByVal value As String, ByVal ch As Char) As Integer
  Return (New System.Text.RegularExpressions.Regex(ch)).Matches(value).Count
End Function

Ответ 15

eCount = str.Length - Replace(str, "e", "").Length
tCount = str.Length - Replace(str, "t", "").Length

Ответ 16

Другая возможность - использовать регулярное выражение:

string a = "this is test";
string pattern = "t";
System.Text.RegularExpressions.Regex ex = new System.Text.RegularExpressions.Regex(pattern);
System.Text.RegularExpressions.MatchCollection m = ex.Matches(a);
MessageBox.Show(m.Count.ToString());

Пожалуйста, преобразуйте это в VB.NET.

Ответ 17

Я нашел лучший ответ: P:

String.ToString.Count - String.ToString.Replace("e", "").Count
String.ToString.Count - String.ToString.Replace("t", "").Count

Ответ 18

    'trying to find the amount of "." in the text
    'if txtName looks like "hi...hi" then intdots will = 3
    Dim test As String = txtName.Text
    Dim intdots As Integer = 0
    For i = 1 To test.Length
        Dim inta As Integer = 0 + 1
        Dim stra As String = test.Substring(inta)
        If stra = "." Then
            intdots = intdots + 1
        End If
    Next
    txttest.text = intdots

Ответ 19

Я использую LINQ, и решение очень просто:

Код в С#:

count = yourString.ToCharArray().Count(c => c == 'e');

Код в функции:

public static int countTheCharacters(string str, char charToCount){
   return str.ToCharArray().Count(c => c == charToCount);
}

Вызвать функцию:

count = countTheCharacters(yourString, 'e');

Ответ 20

Использование:

Function fNbrStrInStr(strin As Variant, strToCount As String)
    fNbrStrInStr = UBound(Split(strin, strToCount)) - LBound(Split(strin, strToCount))
End Function

Я использовал strin как вариант для обработки очень длинного текста. Разделение может быть основано на нуле или на основе одного для низкого конца в зависимости от пользовательских настроек, а вычитание гарантирует правильное количество.

Я не включил проверку того, что strcount длиннее strin, чтобы сделать код кратким.

Ответ 21

Какие огромные коды для чего-то такого простого:

В С# создайте метод расширения и используйте LINQ.

public static int CountOccurences(this string s, char c)
{
    return s.Count(t => t == c);
}

Использование:

int count = "toto is the best".CountOccurences('t');

Результат: 4.

Ответ 22

var charCount = "string with periods...".Count(x => '.' == x);

Ответ 23

Я использую следующую функцию. Это не самая эффективная память, но ее очень просто понять, поддерживает несколько методов сравнения, всего 4 строки, быстро, в основном работает в VBA, найдет не только отдельные символы, но и любую строку поиска (я часто ищу VbCrLf (ы)).

Единственное, чего не хватает, это возможность начать поиск с другого "Пуск"

    Function inStC(myInput As String, Search As String, Optional myCompareMethod As Long = CompareMethod.Text) As Long
        If InStr(1, myInput, Search, myCompareMethod) = 0 Then Return 0
        Return UBound(Split(myInput, Search,, myCompareMethod))
    End Function

Одна вещь, которая мне нравится, - это компактный пример использования.

str="the little red hen"
count=inStC(str,"e") 'count should equal 4
count=inStC(str,"t") 'count should equal 3

В то время как я здесь, я хотел бы зашить мою функцию inStB, которая вместо того, чтобы возвращать количество строк, будет просто возвращать логическое значение, если строка поиска присутствует. Мне нужна эта функция часто, и это делает мой код более чистым.

Function inStB(myInput As String, Search As String, Optional Start As Long = 1, Optional myCompareMethod As Long = CompareMethod.Text) As Boolean
    If InStr(Start, myInput, Search, myCompareMethod) > 0 Then Return True
    Return False
End Function

Ответ 24

Использование:

Dim a
inputString = InputBox("Enter String", "Enter Value", "")

MyString = UCase(inputString)

MsgBox MyString

Dim stringLength

stringLength = Len(MyString)

Dim temp

output = ""

i = 1
Do
    temp = Mid(MyString, i, 1)

    MsgBox temp & i

    CharacterCount = len(MyString) - len(Replace(MyString, temp, ""))

    MyString = Replace(MyString, temp, "")

    output = output & temp & ": " & CharacterCount & vbNewline

Loop While MyString <> ""

MsgBox output

Ответ 25

Private Sub Data_KeyPress(sender As Object, e As KeyPressEventArgs) Handles Data.KeyPress
    If Not IsNumeric(e.KeyChar) And Not e.KeyChar = ChrW(Keys.Back) And Not e.KeyChar = "." Then
        e.Handled = True
    Else
        If e.KeyChar = "." And Data.Text.ToCharArray().Count(Function(c) c = ".") > 0 Then
            e.Handled = True
        End If
    End If
End Sub

Ответ 26

Вот прямой код, который решает проблему OP:

        Dim str As String = "the little red hen"

        Dim total As Int32

        Dim Target As String = "e"
        Dim Temp As Int32
        Dim Temp2 As Int32 = -1
Line50:
        Temp = str.IndexOf(Target, Temp2 + 1)
        Temp2 = Temp
        If Temp <> -1 Then

            ' Means there is a target there
            total = total + 1
            GoTo Line50
        End If

        MessageBox.Show(CStr(total))

Теперь это удобная функция для решения проблемы OP:

    Public Function CountOccurrence(ByVal YourStringToCountOccurrence As String, ByVal TargetSingleCharacterToCount As String) As Int32
        Dim total As Int32

        Dim Temp As Int32
        Dim Temp2 As Int32 = -1
Line50:
        Temp = YourStringToCountOccurrence.IndexOf(TargetSingleCharacterToCount, Temp2 + 1)
        Temp2 = Temp
        If Temp <> -1 Then

            ' Means there is a target there
            total = total + 1
            GoTo Line50
        Else
            Return total
        End If
    End Function

Пример использования функции:

Private Sub Button1_Click(sender As System.Object, e As System.EventArgs) Handles Button1.Click
    Dim str As String = "the little red hen"

    MessageBox.Show(CStr(CountOccurrence(str, "e")))
    ' It will return 4
End Sub