Skip to main content

regex

Regular expressions are a kind of language within a language, designed to help programmers with their searching task.
in general, a regex search runs from left to right, and once a source's character has been used in match, it can't be reused.

metacharacter:

  • \d  digit
  • \s  white space 
  • \w word character (letter, digit or "_")
  • [a-f] range from a to f 
[a-fA-F]  looking for the occurrences of a-f or A-f not fA combination
  • ^ to negate the character specified
  • nested brackets  to create a union set
  • && to specify intersection of a set
  • quantifiers "allows to specify number of occurrences to match against "
    • +  one or more
    • *  zero or more
    • ?  zero or one

    • greedy: read first the whole string, if no match, move backward character by character till a match is found.
    • reluctant , however, take the opposite approach: They start at the beginning of the input string, then move forward searching for match The last thing to try is the entire input string.
    • moving from greedy to reluctant add ? so find? --> find??


To match a pattern exactly n number of times, simply specify the number inside a set of braces  ex: a{3}
To require a pattern to appear at least n times, add a comma after the number a{3,}

Pattern pattern = Pattern.compile("regex");
Matcher matcher=pattern.matcher("String to look into");
matcher.find() start searching, matcher.group() for retrieving matched string




Comments

Popular posts from this blog

The post-office & the postman

If we were to talk about old messaging system where there exist post-office, postman & mailbox. each component had its own functionality that we looked for when trying to visualize how those component where to interact in a computerized version. Simple scenario: Mail is added in mail box Postman arrive pick mails from his area mailboxes and take them to the post-office. Post-office organize mails by areas. Postman takes mails related to his area "distribute it in mailboxes". A person can go to post-office and  pick his own mail "in case of failure or wishes for early delivery". Mapping in a computerized version: Scenario: Observer design pattern which can use push or pull scenario, to inform those whom are registered for an event about its occurrence. Component: Post-Office = Message-Broker Post-Office-Box = Message-Storage-Validity Mailbox = Topic/Queue Postman !!! where's the postman ? Apache kafka act as a message broker which d...

Not all Ps sting

  If someone meant to say Ps and pronounce it Bees. would this confuse you :). Ps is for the P that is the start of Properties and Practice Each application should have some properties and follow certain practices. Properties: Below are 5 properties we should try to have in our application with a small description of how to include them Scalable, Scale => Increase workload (horizontally scaling) Statless, no state should be shared among different application instances,  Concurrency, concurrent processing = Threads. Loosely coupled, decompose the system into modules, each has minimal dependencies on each other "modularization", encapsulating code that changes together "High cohesion".  API first, Interfaces, implementation can be changed without affecting other application. favor distribution of work across different teams.  Backing Services, "DB, SMTP, FTP ..." , treating them as attached resources, meaning they can easily be changed. Manageable, changi...

exploring black box

Once loved watching a comic old movie, where a clause was often said:"what's in this ring box ?" accompanied with a surprising answer:"an elephant is in this ring box " :o Reflection discover whats in the black box "an object", could know what is in an object as if a mirror that reflects it content "ability to examine the run-time properties of the object " small ex wanted to return a generic list containing result of a sql query "as if hibernate" List<T>list=new ArrayList<T>(); ResultSetMetaData metadata=resultSet.getMetaData(); String[] columnName=new String[metadata.getColumnCount()]; for(int i=0;i<columnName.length;i++){//column name equivalent to object instance variable      columnName[i]=metadata.getColumnLabel(i+1); } int index=0; T t; while (resultSet.next()) {   list.add((T)cls.newInstance()); t=list.get(index); for(int i=0;i<columnName.length;i++){//initializati...