ID:               16681
 Updated by:       [EMAIL PROTECTED]
 Reported By:      [EMAIL PROTECTED]
 Status:           Open
 Bug Type:         Feature/Change Request
 Operating System: Windows XP Home Edition
 PHP Version:      4.1.2
 New Comment:

I have a few points to add:

1) YOU CANNOT ALWAYS CHOOSE THE STARTING FORMAT

Daniel says that instead of:
  $countries = "England Spain France Italy";
we should code:
  $countries = array("England", "Spain", "France", "Italy");
but it is not always so easy to start with an array.  Let me give a
real world example.

I am currently writing a search engine, where the user may type
whatever they want; I want to match not just the whole search term, but
each individual word.  So, if the user types "Baptist churches", I can
match "Baptist" and "churches".

// $search_string = "Baptist churches"

// Loop for the number of words in the string
for ($i=0; $i<=words($search_string); $i++) {
  // Get the matches for the i-th word
  get_matches(word($search_string, $i));
}

I agree that we CAN get the words using regular expressions.  That
brings me to my next point.

2) IT IS NOT EASY FOR PEOPLE TO CORRECTLY USE REGULAR EXPRESSIONS TO
GET WORDS.

If you are reading this, you are probably a highly skilled PHP
programmer, able to create first time a correctly functioning regular
expression.  And one which functions correctly for ALL inputs.

This example in the ereg section from the PHP documentation itself does
NOT always give the correct result:

ereg ("([[:alnum:]]+) ([[:alnum:]]+) ([[:alnum:]]+)", $string,$regs); 
/* Places three space separated words
   into $regs[1], $regs[2] and $regs[3]. */

For example, in my real search engine example, a user searching "C++ or
C" would be disappointed to find that I have searched for "C" or "C"! 


And of course regular expressions do not use the locale.

3) THE OBJECT-ORIENTED VIEW OF STRINGS DEMANDS THE PROPOSED WORD
FUNCTIONS

It goes against OO to convert a string into an array, just because
string lacks a function (i.e. words) that array has (i.e. count).  If
we view the string as an object, it is not satisfactory to say that we
can convert the object to another object type and use the functions
which exist for that object type.  It is rather like saying that we do
not need an addition operator for integers because we are able to
convert integers to doubles/floats in order to add.

4) CONSISTENCY

There already exists the 'ucwords()' function, so it is accepted that a
word is a valid concept within a string.

Hugh


Previous Comments:
------------------------------------------------------------------------

[2002-04-20 08:45:12] [EMAIL PROTECTED]

I notice this example in the ereg section:

ereg ("([[:alnum:]]+) ([[:alnum:]]+) ([[:alnum:]]+)", $string,$regs); 
/* Places three space separated words
   into $regs[1], $regs[2] and $regs[3]. */

which could become something like the following with the proposed
word() function:
$regs[1] = word($string, 1);
$regs[2] = word($string, 2);
$regs[3] = word($string, 3);

Even for hardened regular expression fans, I'm sure you would agree
which would be nicer to encounter in somebody elses uncommented code.

And I know which I'd rather place my money on as working correctly.

Hugh

------------------------------------------------------------------------

[2002-04-19 04:59:54] [EMAIL PROTECTED]

This does not warrant new functions. What you are trying to do should
be done with arrays:

/**************************/
$countries = array("England", "Spain", "France", "Italy");

print "There are " . count($countries) . " countries competing";

print "The " . count($countries) . " are:";

for ($i=0; $i<count($countries); $i++) {
  print $countries[$i];
}
/***************************/

if you have an input string like:

  $string = "England Spain France Italy";

you can make an array of it:

  $countries = preg_split("/\s+/", $string);

Still, the proposed functions look like a good addition to the language
as people do not want to study regular expressions.

------------------------------------------------------------------------

[2002-04-19 04:32:04] [EMAIL PROTECTED]

When I was coding the sample code with the $countries (above), I
realised that PHP also misses some other crucial functions for word
processing.  These are basic word functions which I am used to having
in a powerful language.

Therefore, request changed to request words(), word(), wordindex(),
wordlength() functions.

Hugh Prior

------------------------------------------------------------------------

[2002-04-19 04:28:16] [EMAIL PROTECTED]

Derek,

This function is EXTREMELY useful.  The words() function is to strings
what the sizeof() function is to arrays!  I cannot imagine living
without the sizeof() function when dealing with arrays; if I were
dealing with strings a lot I cannot imagine living without a words()
function.

Here's some example code which shows how elegant it can make string
use:  

/**************************/
$countries = "England Spain France Italy";

print "There are " . words($countries) . " countries competing";

print "The " . words($countries) . " are:";

for ($i=0; $i<=words($countries); $i++) {
  print word($countries, $i);
}
/***************************/

Of course, there are many other uses, but this I hope gives a flavour
for how handy and elegant such functionality is.

------------------------------------------------------------------------

[2002-04-19 04:22:01] [EMAIL PROTECTED]

I wish to expand this request to suggest full support for word
processing in strings.  This is something which is extremely useful (it
appears for example in REXX) when processing strings.

word (str, num) 
Returns the num'th word from string str. If num is greater than the
number of words in str, the null string is returned. 
 
wordindex (str, num) 
Returns the character position of the first letter of the num'th word
in string str, or 0 if num is greater than the number of characters in
str. 
 
wordlength (str, num) 
Returns the length of the num'th word in string str, or 0 if num is
greater than the number of words in str. 
 
words (str, num)
Returns the number of words in the string str.

------------------------------------------------------------------------

The remainder of the comments for this report are too long. To view
the rest of the comments, please view the bug report online at
    http://bugs.php.net/16681

-- 
Edit this bug report at http://bugs.php.net/?id=16681&edit=1

Reply via email to