Closed. This question needs details or clarity. It is not currently accepting answers.
Want to improve this question? Add details and clarify the problem by editing this post.
Closed 8 years ago.
Improve this question
Hi i need filter a string with a regular expresion. I have read that I must use the method Replace of the class Regex with a pattern but I don't know that Expresion Regular I need to filter my String.
I have a large string s and I want extract or filter the ? in the next pattern of the string:
"string fixed?_IP"
string fixed is a string that always is the same
IP is a valid IP number
Please I need the pattern to pass to the function Replace of the class Regex to obtain the string ?
I try some patterns but anyone works.
pattern1="(ftp_files\\?_[0-9]+.[0-9]+.[0-9]+.[0-9]+)"
pattern2= "(ftp_files\\?_/^(([1-9]?[0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5]).){3}([1-9]?[0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])$/)"
ftp_files\ is the string fixed
In pattern2 I try an expresion regular that I have found to validate an IP.
You don't need to call Regex.Replace if what you want is to extract the information. You have to call Regex.Match for that. Or, if you really want to call Replace, please tell us what part you want to replace, and what should the substitute look like.
var match = Regex.Match(inputString, #"ftp_files\\\?_(?<ip>\d+\.\d+\.\d+\.\d+)");
var ipAddress = match.Groups["ip"].Value;
Here I chose a more legible regex for the ip address (\d+\.\d+\.\d+\.\d+). If you really need to ensure each byte of the IP is valid, you could replace each instance of \d+ in that expression with something like this: (?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?).
EDIT: If you want to extract what's between ftp_files\ and _IP, here's the regex:
var match = Regex.Match(inputString, #"ftp_files\\(?<value>.*?)_(?<ip>\d+\.\d+\.\d+\.\d+)");
var value = match.Groups["value"].Value;
Related
Closed. This question needs details or clarity. It is not currently accepting answers.
Want to improve this question? Add details and clarify the problem by editing this post.
Closed 2 months ago.
Improve this question
I have shared the relevant image below.
Text in image ;
"C:\Users\Hp\OneDrive-blablablabla\Masaustu\EdaGorsel\4.PNG\tmanager\tmanager\t2022/12/12\r\nddd\tV1.0"
I only want 4.PNG from the above post
2.I should not use special names or filenames
3.Ex: \t between \ like this
I hope I was able to explain my problem
you could use a Regex match to get this part of the url :
private Regex _regex = new Regex(#"^.*\\(?<Image>.*\.PNG)\\.*$");
(You can test regex here)
Then use this to read the match :
var result = _regex.Match(url).Groups["Image"].Value;
Another, simplier solution, would be to use :
url.Split("\\")[6];
This works only if the searched part is always at the same spot.
You can split your strings into many shorter ones using .Split function:
string[] words = path.Split("\\");
Using the double \ to escape the character..
If you don't guarantee that the string you need is always at the same position, you can use this to fetch it from the list:
string neededString = words .FirstOrDefault(str => str.Contains(".PNG"));
This will return the first instance of any word from your string that contains ".png" in it.
there is sevral ways
if you know number of "" in your string then split it(str.Split(' \ ')) and get wanted index
use regular expersion to extract filename
Closed. This question needs to be more focused. It is not currently accepting answers.
Want to improve this question? Update the question so it focuses on one problem only by editing this post.
Closed 1 year ago.
Improve this question
I have a URL string that is something like below:
https://example.com/app/1095600/example2234
I want to only get "1095600"
this number is variable and can be three or more digits long.
If the number is always in the same position (following https://example.com/app/), you could split the string by the slash (/) character and extract it:
string input = "https://example.com/app/1095600/example2234";
string result = input.Split("/")[4];
You can try matching the required substring with a help of regular expressions, esp. if you have elaborated criteria
three or more digits
Code:
using System.Text.RegularExpressions;
...
string url = "https://example.com/app/1095600/example2234";
string number = Regex.Match(url, #"(?<=\/)[0-9]{3,}(?=\/|$)").Value;
Mureinik's answer will work fine, but can quickly break if your URL is missing the https:// part. It would be much better to convert the string to a Uri and use the Uri.Segments property to extract the second segment of the path.
Uri address = new Uri("https://example.com/app/1095600/example2234");
string id = address.Segments[2].Replace("/", "");
The segments include the ending slash, so you need to remove it manually.
Identify the begining, and the ending string marks.
Beginning = "/app/", Ending = "/".
Cut it out of there.
String input = "https://example.com/app/1095600/example2234";
String str_number = input.Substring(input.IndexOf("/app/")+5).Split('/')[0];
int int_number = Convert.ToInt32(str_number);
Always try to write the simplest code you can get. And have fun!
Closed. This question needs to be more focused. It is not currently accepting answers.
Want to improve this question? Update the question so it focuses on one problem only by editing this post.
Closed 6 years ago.
Improve this question
I have a string whose text is something like:
Ebook/AspNetBook.Pdf/.NetBook
or
Ebook/Asp.Net/AspNetBook.Pdf/.NetBook
or may be this
Ebook/Asp.Net/.NetBook/AspNetBook.Pdf
That means string may be come with many forward slashes and it will not come in fix format. I want to get file name and its ext AspNetBook.Pdf from this string.
I have tried to get string to using sub string or replace character before period but do not get proper result.
If your strings always have that particular form string1/string2/string3 you can either use a simple string split or a regular expression.
var xx = input.Split('/')[1];
Or
var xx = Regex.Match(input, #".+/(.+)/.+").Groups[1].Value;
Be aware, this contains no error checking, for instance if the input does not match the given form
This might help you.
string st = "Ebook/AspNetBook.Pdf/.NetBook";
string newst = st.Substring(st.IndexOf('/') + 1);
string outptst = newst.Substring(0,newst.IndexOf('/'));
since you wanted to get the string between 2 forward slashes. This would give you the correct output required.
Try with this:
string st = "Ebook/AspNetBook.Pdf/.NetBook";
string out = st.Split('/')[1];
Be aware that this will only work if you always have a / in your input and if it is always the second value.
Here p1 will find first index of '/' and p2 will index of '/' right after p1.
String text= "Ebook/AspNetBook.Pdf/.NetBook";
int p1=text.indexOf('/');
int p2=-1;
if(p1!=-1)
p2=text.indexOf('/',p1+1);
if(p1!=-1&&p2!=-1)
System.out.print(text.substring(p1+1,p2);
Closed. This question needs details or clarity. It is not currently accepting answers.
Want to improve this question? Add details and clarify the problem by editing this post.
Closed 6 years ago.
Improve this question
I have following text with me,
File <a class='ub link' data-menu-identifier='files' data-url-identifier='/files/detail/n0tlz'>Medical bills & LTA.xlsx</a> was attached to the case by {updatedby} on {updatedon}
What I need is, I need regex that will give me 'n0tlz' from the given text. Please take note that this is not static I need to extract from this pattern.
I have achieved at some level but not getting how to get required text;
I have : '/files/detail/n0tlz' where '/files/detail/{code}' is always there, I just want value of {code} in given sample {code} = n0tlz
// Extract The filecode
const string pattern = #"files\/detail\/(.*)'>";
// Instantiate the regular expression object.
var r = new Regex(pattern, RegexOptions.IgnoreCase);
// Match the regular expression pattern against a text string.
var m = r.Match(fileUpdate.UpdateText);
here m has value : /files/detail/n0tlz'>
but I just wants 'n0tlz' I feels I am too close, just one last step is requires to obtain code value.
// Extract The filecode
const string pattern = #"files\/detail\/(.*)'>";
// Instantiate the regular expression object.
var r = new Regex(pattern, RegexOptions.IgnoreCase);
// Match the regular expression pattern against a text string.
var m = r.Match(fileUpdate.UpdateText);
if (m.Success && m.Groups.Count == 2 )
{
m.Groups[1].Value; // This is the expected result
}
If data-url-identifier='/files/detail/n0tlz'> always contains a '> you could use that as a delimiter. making your existing
files\/detail\/ into files\/detail\/ '>
now to capture the specific value you can use a simple capture group
(.*) which will catch any character between zero and unlimited times.
Combining the 2 would lead to files\/detail\/(.*)'>.
Edit
But this m have : /files/detail/n0tlz'> I just want 'n0tlz' can i get it?
Well, yes. Or to be even more detailed, you already have it!
Instead of using a var try defining the type itself. In this case that would be a Match. Taking a look at the properties you will see that it contains a lot more then just the whole match.
Groups will contain your value
Closed. This question needs details or clarity. It is not currently accepting answers.
Want to improve this question? Add details and clarify the problem by editing this post.
Closed 9 years ago.
Improve this question
So I am trying to replace the characters below from a users input which relates to a SQL column in a table.
Example:
User creates a field called My(first)try. In SQL this comes up as Myfirsttry.
I am currently write code to replace the users input with our and I am stuck.
I have this so far.
itemreplace = itemreplace.Replace("(", "");
This however, doesn't do the trick. Thoughts, comments, suggestions?
I feel like the real-world case is more complicated, and you're not indicating that, but to handle your example text My(first)try you could just chain the Replace statements:
itemreplace = itemreplace.Replace("(", "").Replace(")", "");
However, it seems like the real-world case is more along the lines of leveraging a Regex like this:
^[a-zA-Z0-9_##][a-zA-Z0-9#$#_]*$
and here is a Regex 101 that would prove that.
Then using that might look like this:
var valid = Regex.IsMatch("My(first)try", pattern);
I did reference this post, What special characters are allowed in T-SQL column name?, to determine the allowed characters for a column name.
First option:
String itemreplace = new String("My(first)try");
String charsToRemove = new String[] {"(", ")"};
foreach (char c in charsToRemove)
{
itemreplace = itemreplace.Replace(c, string.Empty);
}
Second option:
itemreplace = itemreplace.Replace("(", string.Empty).Replace(")", string.Empty);