首頁 php教程 php手册 重新实现PHP脚本引擎内置函数

重新实现PHP脚本引擎内置函数

Jun 21, 2016 am 08:57 AM
return str string

以下为引用的内容:

// 实在无聊,突发奇想,想把PHP里面部分已经提供封装好的函数重新使用PHP实现一遍,

// 于是便有了下面的代码主要实现了PHP中部分字符串处理函数,同时实现了一些PHP中

// 没有,但是同样有作用的字符串处理函数同样的这些函数,也能够使用其他语言来实

// 现,比如用C/VBScript/Perl等等,那么你就能够有一个自己的函数库.

// 以下函数不一定能够成功运行,只是为了学习而已。

//

// 如果无特别声明,全部是由于heiyeluren原创,要使用任何函数都请保留作者信息

/**

* String Functions Reconstruct

*

* Copyright (c) 2005 heiyeluren

* Author: heiyeluren

* $Id: StringFunctions.php,v 0.1 e 2005-5-29 23:21 heiyeluren Exp $

**/

// {{{ strlen()

/**

* Count string length

*

* @param string $str need count length string variable

* @return int return count result

* @version v0.1

* @create 2005-5-24

* @modified 2005-5-24

* @author heiyeluren

*/

function strlen1($str)

{

if ($str == '')

return 0;

$count = 0;

while (1)

{

if ($str[$count] != NULL)

{

$count++;

continue;

}

else

break;

}

return $count;

}

// }}}

// {{{ substr()

/**

* Get sub string

*

* @param string $str need get sub string variable

* @param int $start start get sub string

* @param int $length need get string length

* @return string return sub string

* @version v0.2

* @create 2005-5-24

* @modified 2005-5-25

* @author heiyeluren

*/

function substr1($str, $start, $length=0)

{

if ($str == '')

return;

if ($start > strlen($str))

return;

if (($length != NULL) && ($start > 0) && ($length > strlen($str)-$start))

return;

if (($length != NULL) && ($start strlen($str)+$start))

return;

if ($length == NULL)

$length = (strlen($str) - $start);

if ($start

{

for ($i=(strlen($str)+$start); $i

{

$substr .= $str[$i];

}

}

if ($length > 0)

{

for ($i=$start; $i

{

$substr .= $str[$i];

}

}

if ($length

{

for ($i=$start; $i

{

$substr .= $str[$i];

}

}

return $substr;

}

// }}}

// {{{ strrev()

/**

* Reversal string order

*

* @param string $str need reversal string variable

* @return string reversal string

* @version v0.1 www.knowsky.com

* @create 2005-5-24

* @modified 2005-5-24

* @author heiyeluren

*/

function strrev1($str)

{

if ($str == '')

return 0;

for ($i=(strlen($str)-1); $i>=0; $i--)

{

$rev_str .= $str[$i];

}

return $rev_str;

}

// }}}

// {{{ strcmp()

/**

* String comparison

*

* @param string $s1 first string

* @param string $s2 second string

* @return int return -1,str1 str2, str1 = str2,

* return 0, other, return false

* @version v0.1

* @create 2005-5-24

* @modified 2005-5-24

* @author heiyeluren

*/

function strcmp1($s1, $s2)

{

if (strlen($s1)

return -1;

if (strlen($s1) > strlen($s2))

return 1;

for ($i=0; $i

{

if ($s1[$i] == $s2[$i])

continue;

else

return false;

}

return 0;

}

// }}}

// {{{ strchr(), strstr(), strpos()

/**

* Find first occurrence of a string

*

* @param string $str parent string

* @param string $substr need match sub string

* @return int return find sub string at parent string first place,

* f not find, return false

* @version v0.4

* @create 2005-5-24

* @modified 2005-5-29

* @author heiyeluren

*/

function strchr1($str, $substr)

{

$m = strlen($str);

$n = strlen($substr);

if ($m

return false;

for ($i=0; $i

{

$sub = substr($str, $i, $n);

if (strcmp($sub, $substr) == 0)

return $i;

}

return false;

}

// }}}

// {{{ str_replace()

/**

* Replace all occurrences of the search string with the replacement string

*

* @param string $substr need replace sub string variable

* @param string $newsubstr new sub string

* @param string $str operate parent string

* @return string return replace after new parent string

* @version v0.2

* @create 2005-5-24

* @modified 2005-5-29

* @author heiyeluren

*/

function str_replace1($substr, $newsubstr, $str)

{

$m = strlen($str);

$n = strlen($substr);

$x = strlen($newsubstr);

if (strchr($str, $substr) == false)

return false;

for ($i=0; $i

{

$i = strchr($str, $substr);

$str = str_delete($str, $i, $n);

$str = str_insert($str, $i, $newstr);

}

return $str;

}

// }}}

/************ 以下串处理函数是PHP中没有的,自己写着玩 ***************/

// {{{ insert_str(), delete_str(), index_str()

/**

* Basic string operate

*

* @param string $str need get sub string variable

* @param int $start start get sub string

* @param int $length need get string length

* @return string return sub string

* @version v0.1

* @create 2005-5-24

* @modified 2005-5-24

* @author heiyeluren

*/

function str_insert($str, $i, $substr)

{

for($j=0; $j

{

$startstr .= $str[$j];

}

for ($j=$i; $j

{

$laststr .= $str[$j];

}

$str = ($startstr . $substr . $laststr);

return $str;

}

function str_delete($str, $i, $j)

{

for ($c=0; $c

{

$startstr .= $str[$c];

}

for ($c=($i+$j); $c

{

$laststr .= $str[$c];

}

$str = ($startstr . $laststr);

return $str;

}

// }}}

// {{{ strcpy()

/**

* Use designate sub string replace string

*

* @param string $str need get sub string variable

* @param int $start start get sub string

* @param int $length need get string length

* @return string return sub string

* @version v0.1

* @create 2005-5-27

* @modified 2005-5-27

* @author heiyeluren

*/

function strcpy($s1, $s2)

{

if (strlen($s1) == NULL)

return;

if (!isset($s2))

return;

for ($i=0; $i

{

$s2[] = $s1[$i];

}

return $s2;

}

// }}}

// {{{ strcat()

/**

* Use designate sub string replace string

*

* @param string $str need get sub string variable

* @param int $start start get sub string

* @param int $length need get string length

* @return string return sub string

* @version v0.1

* @create 2005-5-27

* @modified 2005-5-27

* @author heiyeluren

*/

function strcat($s1, $s2)

{

if (!isset($s1))

return;

if (!isset($s2))

return;

$newstr = $s1 . $s2;

return $newsstr;

}

// }}}

// {{{ php_encode(), php_decode()

/**

* Simple string encode/decode function

*

* @param string $str need code/encode string variable

* @return string code/encode after string

* @version v0.2

* @create 2005-3-11

* @modified 2005-5-24

* @author heiyeluren

*/

/* String encode function */

function php_encode($str)

{

if ($str=='' && strlen($str)>128)

return false;

for($i=0; $i

{

$c = ord($str[$i]);

if ($c>31 && $c

$c += 20;

if ($c>106 && $c

$c -= 75;

$word = chr($c);

$s .= $word;

}

return $s;

}

/* String decode function */

function php_decode($str)

{

if ($str=='' && strlen($str)>128)

return false;

for($i=0; $i

{

$c = ord($word);

if ($c>106 && $c

$c = $c-20;

if ($c>31 && $c

$c = $c+75;

$word = chr($c);

$s .= $word;

}

return $s;

}

// }}}

// {{{ php_encrypt(), php_decrypt()

/**

* Simple string encrypt/decrypt function

*

* @param string $str need crypt string variable

* @return string encrypt/decrypt after string

* @version v0.1

* @create 2005-5-27

* @modified 2005-5-29

* @author heiyeluren

*/

/* define crypt key */

$encrypt_key = 'abcdefghijklmnopqrstuvwxyz1234567890';

$decrypt_key = 'ngzqtcobmuhelkpdawxfyivrsj2468021359';

/* String encrypt function */

function php_encrypt($str)

{

global $encrypt_key, $decrypt_key;

if (strlen($str) == 0)

return false;

for ($i=0; $i

{

for ($j=0; $j

{

if ($str[$i] == $encrypt_key[$j])

{

$enstr .= $decrypt_key[$j];

break;

}

}

}

return $enstr;

}

/* String decrypt function */

function php_decrypt($str)

{

global $encrypt_key, $decrypt_key;

if (strlen($str) == 0)

return false;

for ($i=0; $i

{

for ($j=0; $j

{

if ($str[$i] == $decrypt_key[$j])

{

$enstr .= $encrypt_key[$j];

break;

}

}

}

return $enstr;

}

// }}}



本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1423
52
Laravel 教程
1321
25
PHP教程
1269
29
C# 教程
1249
24
使用java的String.valueOf()函數將基本資料型別轉換為字串 使用java的String.valueOf()函數將基本資料型別轉換為字串 Jul 24, 2023 pm 07:55 PM

使用Java的String.valueOf()函數將基本資料型別轉換為字串在Java開發中,當我們需要將基本資料型別轉換為字串時,常見的方法是使用String類別的valueOf()函數。這個函數可以接受基本資料類型的參數,並傳回對應的字串表示。在本文中,我們將探討如何使用String.valueOf()函數進行基本資料型別轉換,並提供一些程式碼範例來

C語言return的用法詳解 C語言return的用法詳解 Oct 07, 2023 am 10:58 AM

C語言return的用法有:1、對於傳回值類型為void的函數,可以使用return語句來提前結束函數的執行;2、對於傳回值型別不為void的函數,return語句的作用是將函數的執行結果傳回給呼叫者;3、提前結束函數的執行,在函數內部,我們可以使用return語句來提前結束函數的執行,即使函數並沒有回傳值。

怎麼把char數組轉string 怎麼把char數組轉string Jun 09, 2023 am 10:04 AM

char陣列轉string的方法:可以透過賦值來實現,使用{char a[]=" abc d\0efg ";string s=a;}語法,讓char陣列對string直接賦值,執行程式碼即可完成轉換。

使用java的String.replace()函數替換字串中的字元(字串) 使用java的String.replace()函數替換字串中的字元(字串) Jul 25, 2023 pm 05:16 PM

使用Java的String.replace()函數替換字串中的字元(字串)在Java中,字串是不可變的對象,這意味著一旦創建了一個字串對象,就無法修改它的值。但是,你可能會遇到需要替換字串中的某些字元或字串的情況。這時候,我們可以使用Java的String類別中的replace()方法來實作字串的替換。 String類別的replace()方法有兩種重

Java中return和finally語句的執行順序是怎樣的? Java中return和finally語句的執行順序是怎樣的? Apr 25, 2023 pm 07:55 PM

原始碼:publicclassReturnFinallyDemo{publicstaticvoidmain(String[]args){System.out.println(case1());}publicstaticintcase1(){intx;try{x=1;returnx;}finally{x=3;}}#輸出上述程式碼的輸出可以簡單地得出結論:return在finally之前執行,我們來看下字節碼層面上發生了什麼事情。下面截取case1方法的部分字節碼,並且對照源碼,將每個指令的含義註釋在

使用java的String.length()函數取得字串的長度 使用java的String.length()函數取得字串的長度 Jul 25, 2023 am 09:09 AM

使用Java的String.length()函數取得字串的長度在Java程式設計中,字串是一種非常常見的資料類型,我們經常需要取得字串的長度,即字串中字元的個數。在Java中,我們可以使用String類別的length()函數來取得字串的長度。下面是一個簡單的範例程式碼:publicclassStringLengthExample{publ

2w字 詳解 String,yyds 2w字 詳解 String,yyds Aug 24, 2023 pm 03:56 PM

大家好,今天跟大家分享java基礎之String。 String類別的重要性就不必說了,可以說是我們後端開發用的最多的類,所以,很有必要好好聊聊它。

java的String類別如何使用 java的String類別如何使用 Apr 19, 2023 pm 01:19 PM

一、認識String1.JDK中的String首先我們看看JDK中的String類別源碼,它實作了很多接口,可以看到String類別被final修飾了,這就說明String類別不可以被繼承,String不存在子類,這樣所有使用JDK的人,用到的String類別都是同一個,如果String允許被繼承,每個人都可以對String進行擴展,每個人使用的String不是同一個版本,兩個不同的人使用相同的方法,表現出不同的結果,這就導致程式碼沒辦法進行開發了繼承和方法覆寫在帶來彈性的同時,也會帶來很多子類別行為不

See all articles