У мене є вимога знайти і витягти число, що міститься в рядку.
Наприклад, із цих рядків:
string test = "1 test"
string test1 = " 1 test"
string test2 = "test 99"
Як я можу це зробити?
1.5
? Експоненціальні позначення типу 1.5E45
?
У мене є вимога знайти і витягти число, що міститься в рядку.
Наприклад, із цих рядків:
string test = "1 test"
string test1 = " 1 test"
string test2 = "test 99"
Як я можу це зробити?
1.5
? Експоненціальні позначення типу 1.5E45
?
Відповіді:
пройти через рядок і використовувати Char.IsDigit
string a = "str123";
string b = string.Empty;
int val;
for (int i=0; i< a.Length; i++)
{
if (Char.IsDigit(a[i]))
b += a[i];
}
if (b.Length>0)
val = int.Parse(b);
b == "System.Linq.Enumerable.."
. Правильно (і навіть простіше) було бb = String.Join("", a.Where(char.IsDigit))
new string(char[])
конструктора.
\d+
- це регулярне вираження для цілого числа. Тому
//System.Text.RegularExpressions.Regex
resultString = Regex.Match(subjectString, @"\d+").Value;
повертає рядок, що містить перший вхід числа у subjectString
.
Int32.Parse(resultString)
то дасть вам номер.
Regex.Match(subjectString, @"-?\d+").Value
замість цього
Ось як я очищую телефонні номери, щоб отримати лише цифри:
string numericPhone = new String(phone.Where(Char.IsDigit).ToArray());
string numericPhone =new String(phone.Where(Char.IsDigit).ToArray());
використовувати регулярний вираз ...
Regex re = new Regex(@"\d+");
Match m = re.Match("test 66");
if (m.Success)
{
Console.WriteLine(string.Format("RegEx found " + m.Value + " at position " + m.Index.ToString()));
}
else
{
Console.WriteLine("You didn't enter a string containing a number!");
}
Regex.Split може витягувати числа з рядків. Ви отримуєте всі числа, які знаходяться в рядку.
string input = "There are 4 numbers in this string: 40, 30, and 10.";
// Split on one or more non-digit characters.
string[] numbers = Regex.Split(input, @"\D+");
foreach (string value in numbers)
{
if (!string.IsNullOrEmpty(value))
{
int i = int.Parse(value);
Console.WriteLine("Number: {0}", i);
}
}
Вихід:
Число: 4 Число: 40 Число: 30 Число: 10
Ось Linq
версія:
string s = "123iuow45ss";
var getNumbers = (from t in s
where char.IsDigit(t)
select t).ToArray();
Console.WriteLine(new string(getNumbers));
"123iuow45ss".AsEnumerable().Where(char.IsDigit)
?
from t .. select t
надмірності, але все одно, ура.
Ще одне просте рішення за допомогою Regex. Вам слід скористатися цим
using System.Text.RegularExpressions;
і код є
string var = "Hello3453232wor705Ld";
string mystr = Regex.Replace(var, @"\d", "");
string mynumber = Regex.Replace(var, @"\D", "");
Console.WriteLine(mystr);
Console.WriteLine(mynumber);
Ви також можете спробувати це
string.Join(null,System.Text.RegularExpressions.Regex.Split(expr, "[^\\d]"));
Просто використовуйте RegEx, щоб відповідати рядок, а потім конвертувати:
Match match = Regex.Match(test , @"(\d+)");
if (match.Success) {
return int.Parse(match.Groups[1].Value);
}
Ось ще один Linq
підхід, який витягує перше число з рядка.
string input = "123 foo 456";
int result = 0;
bool success = int.TryParse(new string(input
.SkipWhile(x => !char.IsDigit(x))
.TakeWhile(x => char.IsDigit(x))
.ToArray()), out result);
Приклади:
string input = "123 foo 456"; // 123
string input = "foo 456"; // 456
string input = "123 foo"; // 123
string input = "Hello 20, I am 30 and he is 40";
var numbers = Regex.Matches(input, @"\d+").OfType<Match>().Select(m => int.Parse(m.Value)).ToArray();
Це можна зробити за допомогою String
властивості, як показано нижче:
return new String(input.Where(Char.IsDigit).ToArray());
який дає лише число з рядка.
У запитанні прямо не вказано, що ви просто хочете, щоб символи були від 0 до 9, але не було б думкою, що це вірно з вашого прикладу та коментарів. Отже ось код, який це робить.
string digitsOnly = String.Empty;
foreach (char c in s)
{
// Do not use IsDigit as it will include more than the characters 0 through to 9
if (c >= '0' && c <= '9') digitsOnly += c;
}
Чому ви не хочете використовувати Char.IsDigit () - Числа включають символи, такі як дроби, підписки, надписи, римські цифри, чисельники валют, обведені цифри та спеціальні цифри для сценарію.
Метод розширення для отримання всіх позитивних чисел, що містяться в рядку:
public static List<long> Numbers(this string str)
{
var nums = new List<long>();
var start = -1;
for (int i = 0; i < str.Length; i++)
{
if (start < 0 && Char.IsDigit(str[i]))
{
start = i;
}
else if (start >= 0 && !Char.IsDigit(str[i]))
{
nums.Add(long.Parse(str.Substring(start, i - start)));
start = -1;
}
}
if (start >= 0)
nums.Add(long.Parse(str.Substring(start, str.Length - start)));
return nums;
}
Якщо ви хочете негативні числа, просто змініть цей код, щоб обробити знак мінус (-
)
Враховуючи цей вхід:
"I was born in 1989, 27 years ago from now (2016)"
Отриманий список номерів буде:
[1989, 27, 2016]
якщо число має десяткову точку, ви можете використовувати нижче
using System;
using System.Text.RegularExpressions;
namespace Rextester
{
public class Program
{
public static void Main(string[] args)
{
//Your code goes here
Console.WriteLine(Regex.Match("anything 876.8 anything", @"\d+\.*\d*").Value);
Console.WriteLine(Regex.Match("anything 876 anything", @"\d+\.*\d*").Value);
Console.WriteLine(Regex.Match("$876435", @"\d+\.*\d*").Value);
Console.WriteLine(Regex.Match("$876.435", @"\d+\.*\d*").Value);
}
}
}
результати:
"що-небудь 876,8 нічого" ==> 876,8
"що-небудь 876 що завгодно" ==> 876
"876435 $" ==> 876435
"876,435 $" ==> 876,435
Зразок: https://dotnetfiddle.net/IrtqVt
Зробив зворотній бік однієї з відповідей на це запитання: Як видалити числа з рядка за допомогою Regex.Replace?
// Pull out only the numbers from the string using LINQ
var numbersFromString = new String(input.Where(x => x >= '0' && x <= '9').ToArray());
var numericVal = Int32.Parse(numbersFromString);
string verificationCode ="dmdsnjds5344gfgk65585";
string code = "";
Regex r1 = new Regex("\\d+");
Match m1 = r1.Match(verificationCode);
while (m1.Success)
{
code += m1.Value;
m1 = m1.NextMatch();
}
Цікавий підхід міститься тут Ахмад Mageed, використовує Regex і StringBuilder для вилучення чисел в тому порядку , в якому вони з'являються в рядку.
Приклад використання Regex.Split на основі допису Ахмада Магіда такий:
var dateText = "MARCH-14-Tue";
string splitPattern = @"[^\d]";
string[] result = Regex.Split(dateText, splitPattern);
var finalresult = string.Join("", result.Where(e => !String.IsNullOrEmpty(e)));
int DayDateInt = 0;
int.TryParse(finalresult, out DayDateInt);
ось моє рішення
string var = "Hello345wor705Ld";
string alpha = string.Empty;
string numer = string.Empty;
foreach (char str in var)
{
if (char.IsDigit(str))
numer += str.ToString();
else
alpha += str.ToString();
}
Console.WriteLine("String is: " + alpha);
Console.WriteLine("Numeric character is: " + numer);
Console.Read();
Вам доведеться використовувати Regex як \d+
\d
відповідає цифрам у заданому рядку.
static string GetdigitFromString(string str)
{
char[] refArray = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9' };
char[] inputArray = str.ToCharArray();
string ext = string.Empty;
foreach (char item in inputArray)
{
if (refArray.Contains(item))
{
ext += item.ToString();
}
}
return ext;
}
string s = "kg g L000145.50\r\n";
char theCharacter = '.';
var getNumbers = (from t in s
where char.IsDigit(t) || t.Equals(theCharacter)
select t).ToArray();
var _str = string.Empty;
foreach (var item in getNumbers)
{
_str += item.ToString();
}
double _dou = Convert.ToDouble(_str);
MessageBox.Show(_dou.ToString("#,##0.00"));
Використовуючи @ tim-pietzcker відповідь зверху , буде працювати наступне PowerShell
.
PS C:\> $str = '1 test'
PS C:\> [regex]::match($str,'\d+').value
1
На основі останнього зразка я створив метод:
private string GetNumberFromString(string sLongString, int iLimitNumbers)
{
string sReturn = "NA";
int iNumbersCounter = 0;
int iCharCounter = 0;
string sAlphaChars = string.Empty;
string sNumbers = string.Empty;
foreach (char str in sLongString)
{
if (char.IsDigit(str))
{
sNumbers += str.ToString();
iNumbersCounter++;
if (iNumbersCounter == iLimitNumbers)
{
return sReturn = sNumbers;
}
}
else
{
sAlphaChars += str.ToString();
iCharCounter++;
// reset the counter
iNumbersCounter = 0;
}
}
return sReturn;
}