//Analysis browser function getBrowser($agent){ if(strpos($agent,'MSIE')!==false || strpos($agent,'rv:11.0')) //ie11判断 return "ie"; else if(strpos($agent,'Firefox')!==false) return "firefox"; else if(strpos($agent,'Chrome')!==false) return "chrome"; else if(strpos($agent,'Opera')!==false) return 'opera'; else if((strpos($agent,'Chrome')==false)&&strpos($agent,'Safari')!==false) return 'safari'; else if((strpos($agent,'AppleWebKit')!==false)) return 'safari'; else return 'unknown'; } function getBrowserVer($agent){ if (preg_match('/MSIE\s(\d+)\..*/i', $agent, $regs)) return $regs[1]; elseif (preg_match('/FireFox\/(\d+)\..*/i', $agent, $regs)) return $regs[1]; elseif (preg_match('/Opera[\s|\/](\d+)\..*/i', $agent, $regs)) return $regs[1]; elseif (preg_match('/Chrome\/(\d+)\..*/i', $agent, $regs)) return $regs[1]; elseif ((strpos($agent,'Chrome')==false)&&preg_match('/Safari\/(\d+)\..*$/i', $agent, $regs)) return $regs[1]; elseif (preg_match('/AppleWebKit\/(\d+)\..*/i', $agent, $regs)) return $regs[1]; elseif (preg_match('/Trident\/(\d+)\..*/i', $agent, $regs)) return $regs[1]; else return 'unknow'; } function get_ie_model($agent){ if(strpos($agent,'compatible')!==false){ return 'compatible'; }else{ return ''; } } function getos($agent){ if(strpos($agent,'Macintosh')!==false){ return 'Mac'; } else if(strpos($agent,'Android')!==false){ return 'Android'; } else if(strpos($agent,'Windows')!==false){ return 'Windows'; } else if(strpos($agent,'iPad')!==false){ return 'iPad'; } else if(strpos($agent,'iPhone')!==false){ return 'iPhone'; } else { return 'unknow'; } } function transfer_browser_info(){ ini_set('max_execution_time', '0'); //get customer lkup arr $customer_list = $this->db->query("select customer_id, customer_name from evo_central_config.customer")->result_array(); $customer_lkup = array(); foreach($customer_list as $row){ $customer_lkup[$row['customer_id']] = $row['customer_name']; } $sql = "select count(*) as cnt, login_name, user_agent from evo_central.user_login_trail where login_time > '2015-01-01 00:00:00' and login_password = 'OK' and login_name != '' group by login_name, user_agent" ; $result = $this->db->query($sql)->result_array(); foreach($result as $row) // $query = $this->db->query($sql); // while ($row = $query->unbuffered_row()) { $login_name = $row['login_name']; $agent = $row['user_agent']; #user_id,user_name,customer_id,customer_name,os,browser,version,model $user_info = $this->db->query("select * from evo_central_config.customer_user_online where login_name = '$login_name'")->row_array(); $insert_arr = array(); if(!empty($user_info)){ $insert_arr['cnt'] = $row['cnt']; $insert_arr['user_id'] = $user_info['user_id']; $insert_arr['user_name'] = $user_info['user_name']; $insert_arr['customer_id'] = $user_info['customer_id']; $insert_arr['customer_name'] = !empty($customer_lkup[$insert_arr['customer_id']]) ? $customer_lkup[$insert_arr['customer_id']] : '' ; $insert_arr['os'] = $this->getos($agent); $insert_arr['browser'] = $this->getBrowser($agent); $insert_arr['version'] = $this->getBrowserVer($agent); $insert_arr['model'] = $this->get_ie_model($agent); $insert_arr['agent'] = $agent; $this->db->insert('evo_central.test',$insert_arr); } } }
标签: 技术
PHP脚本的最大执行时间问题
php.ini 中缺省的最长执行时间是 30 秒,这是由 php.ini 中的 max_execution_time 变量指定,倘若你有一个需要颇多时间才能完成的工作,例如要发送很多电子邮件给大量收件者,或者要进行繁重的数据分析工作,服务器会在 30 秒后强行中止正在执行的程序,如何解决这个问题呢。
另一个办法是在 PHP 程序中加入 ini_set('max_execution_time', '0'),数值 0 表示没有执行时间的限制,你的程序需要跑多久便跑多久。若果你的程序仍在测试阶段,推荐你把时限设置一个实数,以免程序的错误把服务器当掉。
<?php //max_execution_time=100; ini_set("max_execution_time", 1); //用此function才能真正在运行时设置 for($i=1; $i< 100000; $i++) { echo "No. {$i}\n"; echo '<br />'; flush(); } ?>
在这里简单记录下~
CI处理大结果集
unbuffered_row() 方法
老版本不支持3.0以上才有
row() 方法一样返回单独一行结果,但是它不会预读取所有的结果数据到内存中。 如果你的查询结果不止一行,它将返回当前一行,并通过内部实现的指针来移动到下一行。
$query = $this->db->query("YOUR QUERY"); while ($row = $query->unbuffered_row()) { echo $row->title; echo $row->name; echo $row->body; }
在IE6,7,8 parseInt()前导为”0″ 转换值不准确
parseInt()有两种模式,通常我们使用普通模式,ECMAScript规范指出,如果一个字符串以“0”开头(而不是“0x”或“0X”开头),parseInt()可能把它解释为一个八进制数或者十进制数。由于这一行为不确定,在IE6,7,8和较低版本的火狐、Opera、Safari、Chrome中,会以八进制方式进行转换,所以造就了这个奇葩的结果。parseInt() 方法还有基模式,可以把二进制、八进制、十六进制或其他任何进制的字符串转换成整数。基是由 parseInt() 方法的第二个参数指定的,所以要解析十六进制的值,需如下调用 parseInt() 方法:
小结:parseInt 函数的完整形式是:parseInt(string, radix),第二个参数是所谓的基数,设置string的格式,常用的有2、8、10、16,表示string是多少进制的数。强烈建议在使用parseInt()解析字符串时指定基数,多数情况下接受用户的输入很有可能得到“050”类似值,为避免不必要的逻辑错误,所以务必要指定基数。例如: parseInt(“050″, 10); //这里指定被解析数字的基数是十进制。避免了各种浏览器解析不一致的问题。
js lpad
function lpad(len,initstr,padstr) { var result=""; for(var i=1;i<=len-initstr.toString().length;i++) { result += padstr; } result += initstr; return result; }
开始在固定位置 达到一定高度后随屏幕滚动
<style type="text/css"> .div1 { height:2000px; } .div2 { width:200px; height:200px; background-color:#3399FF; margin-top:100px; } .div2_1{ position:fixed; width:200px; height:200px; z-index:999; background-color:#3399FF; top:0px; _position:absolute; _bottom:auto; _top:[removed]eval(document.documentElement.scrollTop)); } </style> <script type="text/javascript"> window.onscroll=function(){ var t=document.documentElement.scrollTop||document.body.scrollTop; var div2=document.getElementById("div2"); if(t>= 100){ div2.className = "div2_1"; }else{ div2.className = "div2"; } } </script> <div class="div1"> <div id="div2" class="div2"></div> </div>
更新了FileZilla 连接不上ftp了 解决办法
1. Go to FTP
2. Click on Site Manager under the File menu or press CTRL+S.
3. And select "only use plain FTP (insecure) from the "Encryption" drop down.
python 错误类型
1、NameError:尝试访问一个未申明的变量
NameError: name 'v' is not defined
>>> v = 1/0
3、SyntaxError:语法错误
SyntaxError: invalid syntax (<pyshell#14>, line 1)
>>> List = [2]
Traceback (most recent call last):
List[3]
5、KeyError:字典关键字不存在
>>> Dic['3']
File "<pyshell#20>", line 1, in <module>
KeyError: '3'
>>> f = open('abc')
7、AttributeError:访问未知对象属性
def Work():
>>> w = Worker()
Traceback (most recent call last):
w.a
Traceback (most recent call last):
int('d')
9、TypeError:类型错误
>>> iVal = 22
Traceback (most recent call last):
obj = iStr + iVal;
10、AssertionError:断言错误
Traceback (most recent call last):
assert 1 != 1
http://blog.csdn.net/fcoolx/article/details/4202872
11、 NotImplementedError:方法没实现引起的异常
示例:
class Base(object): def __init__(self): pass def action(self): raise NotImplementedError
13、 如果你不确定数据类型是字典还是列表时,可以用 14、StandardError 标准异常。
除StopIteration, GeneratorExit, KeyboardInterrupt 和SystemExit外,其他异常都是StandarError的子类。
python 笔记
1. %s, %d, %f用法
在python中,print语句和字符操作符结合使用,可实现字符串替换功能。
%s—表示由一个字符串来替换
%d—表示由一个整型来替换
%f—表示由一个浮点型来替换
eg:
>>> print "%s is number %d!" % ("Python",1)
Python is number 1!
2.raw_input()内建函数
raw_input–从标准输入读取一个字符串,并自动删除串尾的换行字符。
a)可将读取的数据赋值给一个变量,作再次使用
>>> user=raw_input("enter your name:")
enter your name:jane
>>> print "your login is:", user
your login is: jane
b)也可使用int()函数将输入的字符串转换为整型
>>> num=raw_input("Now enter a number:")
Now enter a number:1023
>>> print "doubling your number: %d" %(int(num)*2)
doubling your number: 2046
>>> print "doubling your number: %d" %(num *2)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: %d format: a number is required, not str
json_encode 处理中文
我们知道, 用PHP的json_encode来处理中文的时候, 中文都会被编码, 变成不可读的, 类似”\u***”的格式, 还会在一定程度上增加传输的数据量.
而在PHP5.4, 这个问题终于得以解决, Json新增了一个选项: JSON_UNESCAPED_UNICODE, 故名思议, 就是说, Json不要编码Unicode.
echo json_encode("中文", JSON_UNESCAPED_UNICODE);