Jump to content

Barand

Moderators
  • Posts

    24,566
  • Joined

  • Last visited

  • Days Won

    822

Everything posted by Barand

  1. here's mine, with the data you sent weirdsort.php
  2. how's this? usort($data, function($a,$b) { list($a1,$a2,$a3) = splitParts($a); list($b1,$b2,$b3) = splitParts($b); $x = strcmp($a1,$b1); if ($x == 0) { $y = $b2 - $a2; if ($y == 0) { return $b3 - $a3; } return $y; } return $x; }); function splitParts($s) { $k = strlen($s); $a = ['','','']; $i = 0; $p = 0; while ($i < $k) { $c = $s[$i++]; if (ctype_digit($c) && $p==0) $p = 1; if ($c=='-') { $c = $s[$i++]; ++$p; } $a[$p] .= $c; } return $a; }
  3. Thanks, saves a lot of editing Now which bits are ascending and which are descending in the required sort?
  4. More generalized case $x=1; $y=111; $z = $x + $y/pow(10,strlen($y));
  5. As this is a math help forum $x=1; $y=1; $z = $x + $y/10; echo $z;
  6. Post the array again using the output from var_export($array); That gives us processable code. AAA XXXX YYYY - which bits are ASC and which bits DESC?
  7. I copied your extra ")" if ($values['Workings1'] == "F") { $values['ExpiryDate'] = $values['Workings2']; } else if ($values['Workings1'] == "D") { $dateObj = new DateTime($values['IssueDate']); $dateObj->modify("+{$values['Workings3']} days"); $values['ExpiryDate'] = $dateObj->format('Y-m-d'); }
  8. try if ($values['Workings1'] == "F") { $values['ExpiryDate'] = $values['Workings2']; } else if ($values['Workings1'] == "D") { $dateObj = new DateTime($values['IssueDate']); $dateObj->modify("+{$values['Workings3']}) days"); $values['ExpiryDate'] = $dateObj->format('Y-m-d'); }
  9. What is your code where you create $values['IssueDate'] ?
  10. Sounds like you you have "modified_date" column in both tables. You have to specify which one to use order_history.modified_date or research_queue.modified_date
  11. What is the code where you (try to) create the object that is being cloned?
  12. "clone" doesn't use parentheses. EG $copy = clone $obj;
  13. By applying some thought to the problem and coming up with a logical sequence of events.
  14. The trick is to organize your code so that you collect the error messages before you do the print.
  15. Do you expect to see something when you print the contents of an empty array?
  16. OK, so you create an empty array print each value in this empty array put an item into the array So what error are you getting? What are you expecting that isn't happening? What is happening that you don't expect? Give me a clue!
  17. Use your table of member payments so you know which ones have been paid and when.
  18. Then you may be doing something wrong.
  19. Change line 8 to $Privilege = ""; At the moment $Privilege is defined inside a whilef() condition. If the condition is false (no records) then it is not defined.
  20. foreach() loop
  21. What you are now asking for is not what you originally asked for. I am not getting involved in an ever-escalating spiral of requirements (Not for free anyway). Hint: make "Africa/Abidjan" the key of the returned array and "[uTC/GMT +00:00] Africa/Abidjan" the value then build your options using both.
  22. Create a dateTime object for each timezone. Format the time with 'P' format. class Time_zone { private $regions = array( 'Africa' => DateTimeZone::AFRICA, 'America' => DateTimeZone::AMERICA, 'Antarctica' => DateTimeZone::ANTARCTICA, 'Artic' => DateTimeZone::ARCTIC, 'Asia' => DateTimeZone::ASIA, 'Atlantic' => DateTimeZone::ATLANTIC, 'Australia' => DateTimeZone::AUSTRALIA, 'Europe' => DateTimeZone::EUROPE, 'Indian' => DateTimeZone::INDIAN, 'Pacific' => DateTimeZone::PACIFIC ); public function generate_list() { $time_zones = array(); foreach ($this->regions as $name => $mask) { $time_zones[$name] = DateTimeZone::listIdentifiers($mask); } foreach ($time_zones as &$zones) { foreach ($zones as &$zstr) { $zn = new DateTimeZone($zstr); $t = new DateTime('now', $zn); $offset = $t->format('P'); $zstr = "[UTC/GMT $offset] $zstr"; } } return $time_zones; } }
  23. try $data = [ 'A98-1', 'A99-1', 'A2000-1', 'A2003-1', 'A2006-1', 'A2007-1', 'A2009-1', 'A2010-10', 'A2010-9', 'A2010-8', 'A2010-7', 'A2010-6', 'A2010-5', 'A2010-4', 'A2010-3', 'A2010-2', 'A2010-1' ]; usort ($data, function($a, $b) { list($a1,$a2) = explode('-', $a); list($b1,$b2) = explode('-', $b); $x = strnatcmp($b1, $a1); if ($x==0) { return strnatcmp($b2,$a2); } return $x; }); Results: Array ( [0] => A2010-10 [1] => A2010-9 [2] => A2010-8 [3] => A2010-7 [4] => A2010-6 [5] => A2010-5 [6] => A2010-4 [7] => A2010-3 [8] => A2010-2 [9] => A2010-1 [10] => A2009-1 [11] => A2007-1 [12] => A2006-1 [13] => A2003-1 [14] => A2000-1 [15] => A99-1 [16] => A98-1 )
  24. Unfortunately for you, not all appear to be reversed. I have spotted a dozen in the above data that seem to be the correct way round (although in the North Atlantic). For example, the first three that are visible in the above image.
×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.