json_decode解析的问题

如图返回值

$jsoninfo = json_decode($result);  
$errcode = $jsoninfo -> errcode;  //正常
$errmsg = $jsoninfo -> errmsg;    //正常
$card = $jsoninfo -> card;
$cardid = $card -> card_id;          //null

$cardid应该怎么取啊,取出来为空,上面的操作不行,求助各位!

2个回答

这样写是正确的,谢谢大家!

$jsoninfo = json_decode($result);

$errcode = $jsoninfo -> errcode; //正常
$errmsg = $jsoninfo -> errmsg; //正常
$card = $jsoninfo -> card;
$cardid = $card -> card_id; //null

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
php中url接收的json数据,json_decode为空
#php后台json数据decode为结果空# 我使用手机传输数据到php后台,json\_decode的结果为空。 手机传输的方式为POST/GET,编码格式为UTF-8。 json数据为(包括代码中的单引号,我用字符串传输,json数据中必须为双引号): ``` '{"agent":"30","job":"1133","students":[{"working_hours_unit":"null","working_hours":"6","student_id":"191","commission_unit":"null","wage":"58","commission":"348","wage_unit":"null"}]}' ``` php代码获取到了以上json数据,并且能够使用echo输出。php代码: ``` $str=$_GET('my_str'); echo $str; ``` 输出测试结果然后我接着decode接收到的json数据,代码: ``` $form = json_decode($Noel,true); var_dump($form); ``` 但很意外输出为**null** ,然后我用_echo json_last_error();_输出json转换错误,结果为4===json语法错误。 附上完整代码和截图: ``` $str=$_GET('my_str'); echo $str;$form = json_decode($str,true); var_dump($form); echo json_last_error(); ``` ![页面输出结果](https://img-ask.csdn.net/upload/201512/03/1449130975_109289.png) 但是,当我把接收到的json单独接到PHP代码中,然后decode却能够正确解析。(我内心是崩溃的 〒_〒) 代码:` ``` $orm='{"agent":"30","job":"1133","students":[{"working_hours_unit":"null","working_hours":"6","student_id":"191","commission_unit":"null","wage":"58","commission":"348","wage_unit":"null"}]}'; $arr=json_decode($form,true); var_dump($arr); ``` 截图: ![图片说明](https://img-ask.csdn.net/upload/201512/03/1449131163_479632.png)
php json_decode();解析出布尔值true是1,false为空,怎么解决?
<?php header("Content-Type: text/html;charset=utf-8"); $json = '{ "flag":false }'; $j = json_decode($json,true); print_r($j); ``` ``` 结果为--------------------------------- Array ( [flag] => ) ------------------------------- 我就想要布尔值 ture 或者false啊 ,给我吃了啊?
python json解析出现No JSON object could be decoded的报错
源代码:#coding:utf-8 import requests import re import json url="http://www.newrank.cn/public/info/list.js?t=1461063208.68" user_agent = 'Mozilla/4.0 (compatible; MSIE 5.5; Windows NT)' headers = { 'User-Agent' : user_agent } jscontent=requests.get("http://www.newrank.cn/public/info/list.js?t=1461063208.68",headers=headers).content jsdict=json.loads(jscontent) 错误信息:Traceback (most recent call last): File "D:/Python/JetBrains PyCharm 5.0.4/PyCharm 5.0.4/Myproject/test1/test2.py", line 10, in <module> jsdict=json.loads(jscontent) File "D:\Python\lib\json\__init__.py", line 339, in loads return _default_decoder.decode(s) File "D:\Python\lib\json\decoder.py", line 364, in decode obj, end = self.raw_decode(s, idx=_w(s, 0).end()) File "D:\Python\lib\json\decoder.py", line 382, in raw_decode raise ValueError("No JSON object could be decoded") ValueError: No JSON object could be decoded 是因为json的bom头问题吗,我也尝试过一些网上的去除bom头的办法,不过都不管用,还望指点,非常头疼,谢谢!
PHP解析Json时,如何解析保存了对象的数组,
我有如下Json字符串 $Json=[{"ClassName":"Class1501","StuNum":"20152154","StuName":"学生姓名1","ClassID":"1"},{"ClassName":"Class1501","StuNum":"20152230","StuName":"学生姓名2","ClassID":"1"},{"ClassName":"Class1501","StuNum":"20152420","StuName":"学生姓名3","ClassID":"1"},{"ClassName":"Class1501","StuNum":"20152426","StuName":"学生姓名4","ClassID":"1"},{"ClassName":"Class1502","StuNum":"20152093","StuName":"学生姓名5","ClassID":"1"},{"ClassName":"Class1502","StuNum":"20152133","StuName":"学生姓名6","ClassID":"1"},{"ClassName":"Class1502","StuNum":"20152282","StuName":"学生姓名7","ClassID":"1"},{"ClassName":"Class1502","StuNum":"20152451","StuName":"学生姓名8","ClassID":"1"},] 这个json我是在c#端用Litjson打包的,并传到php来处理 在PHP中创建类: class ImportStudentData{ public $StuNum; public $StuName; public $ClassName; public $ClassID; } 如果我这样写 $Arr=array(); $Arr=json_decode($json,true); 解析出来的是一个数组,我能正确访问到数组的长度,但是不能访问数组里的元素(我希望这个数组的内容是ImportStudentData对象) 我的目的: 把这个Json字符串解析到PHP中,并且最后的结果是,把json中每个对象的内容保存到ImportStudentData对象中,并最后存到一个数组里。 $Arr2={ImportStudentData1,ImportStudentData2, ....} 最后,我可以通过 ImportStudentData1->StuNum ImportStudentData1->StuName来得到Json中的内容 最终目的: 我是想把这些玩意,通过php存到数据库中
通过接口传递数据,提交显示成功了,但数据传递不过去,麻烦大神给看一下,
$post_url = ''x'x'x; $headers = array(); $headers[] = 'Content-Type:application/json'; $headers[] = 'Connection:keep-alive'; $headers[] = 'Accept-Encoding:gzip'; $headers[] = 'Accept-Charset:utf-8'; $post_array = array( 'cmd'=>'insertLeaveWord', 'token'=>'245Y7BSfDHIWEie35', 'params'=>array( 'realName'=>$_POST['username'], 'phone'=>$_POST['phone'], 'content'=>$_POST['message'] ) ); $post_data = json_encode($post_array); //模拟post请求 $ch = curl_init();//初始化curl curl_setopt($ch, CURLOPT_URL,$post_url);//抓取指定网页 curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);//设置header curl_setopt($ch, CURLOPT_TIMEOUT, 3); //设置超时 curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);//要求结果为字符串且输出到屏幕上 curl_setopt($ch, CURLOPT_POST, 1);//post提交方式 curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data); $result['data'] = curl_exec($ch); $result['code'] = curl_getinfo($ch, CURLINFO_HTTP_CODE); curl_close($ch); $json_data = json_decode($result['data'],true);//解析json数组 if($json_data['result'] == 0 && $json_data['resultNote'] == 'Success'){ echo '<script>'; echo 'alert("信息已提交,稍后会有客服与您取得联系。");'; echo 'window.location.replace(document.referrer)'; echo '</script>'; }else{ echo '<script>'; echo 'alert("信息已失败,请重试。");'; echo 'window.history.go(-1);'; echo '</script>'; }
Ext中json解析如何获取属性名
在Ext中解析json数据用Ext.decode(str); 比如{'value':'this is value'}这个,我应该怎么获取到value呢?我知道获取“This is value”是通过obj.value,可是value是动态的,我怎么知道obj下有没有value这个属性名呢?
Ext 与过滤器结合问题
通过EXT制作登录表单,登录成功后通过过滤器直接跳转到指定页面,如:login.jsp-->index.jsp,在跳转到的index页面老是报错:Ext.JSON.decode(): You're trying to decode an invalid JSON String: index页面的内容,应该是解析JSON数据错误,是不是Ext每次返回都要是JSON数据才行?还是说哪些配置有问题,望大侠给予指点下。。TKS~
php for循环请求接口超时
$file =input('post.avatar'); if(!$file){ $this->error('请上传需要导入的表格!支持csv,xls,xlsx格式!'); } $filePath = ROOT_PATH . DS . 'public' . DS . $file; if (!is_file($filePath)) { $this->error('上传的表格不存在,请核实'); } $PHPReader = new \PHPExcel_Reader_Excel2007(); if (!$PHPReader->canRead($filePath)) { $PHPReader = new \PHPExcel_Reader_Excel5(); if (!$PHPReader->canRead($filePath)) { $PHPReader = new \PHPExcel_Reader_CSV(); $PHPReader->setInputEncoding('GBK'); if (!$PHPReader->canRead($filePath)) { $this->error(__('Unknown data format')); } } } for($i=2;$i<=$allRow;$i++){ switch ($express_id) { case 1: //接口请求参数 $post_info = [ ]; //请求接口 $json = sendRequest('',$post_info,'POST'); $return = json_decode($json,1); $code = $return['code']; if($code==0){ $return_data = $return['data']; $taskid = $return_data['recordId']; //处理成功时的业务逻辑 $result = []; $result[$i] = [ ]; //更新用户信息 $yu_money = $yu_money-$total_fee; \app\common\model\User::score($score=0,'-'.$total_fee,$uid,',编号'.$retu[$i]['id']); $continue_num = $continue_num+1; }else{ $this->error($return['msg']); } break; default: # code... break; } } //循环结束执行业务逻辑 ``` ```用户上传表格->php后台解析表格->通过for循环在循环体内请求外部接口 表格有多少记录循环多少次->当所有for循环执行结束后 处理其他业务 现在的问题就是当表格有500以上的数据时 整个for循环体执行时间太长 导致服务器超时 请问这种情况该怎么解决 对方接口一次最多接收5调数据 上面是我代码的示例 请问这种问题该怎么解决 如果改变请求时间用户体验不好 等待时间过长
传到后台的json数据,如何让springmvc进行解析?
为了更好的说明问题,我把代码贴出来,如下 ``` function submit(){ debugger; var n=$("#countnumber").text(); var i=0; for(var a=0;a<n;a++){ var saveData=new Array(); var arr1=$('.item p').find('input:text'); var arr2=$('.item p').find('input:checkbox'); for(i=0;i<arr1.length;i++){ saveData.push((arr1).eq(i).val()); }; for(var j=0;j<arr2.length;j++){ saveData.push((arr2).eq(j).val()); }; }; function User(userId,userName,userPwd,memo,addDate,modifyDate,addUserId){ this.userId=saveData[1]; this.userName=saveData[2]; this.userPwd=saveData[3]; this.memo=saveData[4]; this.addDate=saveData[5]; this.modifyDate=saveData[6]; this.addUserId=saveData[7]; }; var user=new User(); var users=new Array(); users.push(user); $.ajax({ type: "post",//数据发送的方式(post 或者 get) url: "insert.do",//要发送的后台地址 data: {"user":JSON.stringify(users)}, dataType: "text",//后台处理后返回的数据格式 success:function (data){ alert(jQuery.parseJSON(data).msg); } }); } ``` ``` function submit(){ debugger; var n=$("#countnumber").text(); var i=0; for(var a=0;a<n;a++){ var saveData=new Array(); var arr1=$('.item p').find('input:text'); var arr2=$('.item p').find('input:checkbox'); for(i=0;i<arr1.length;i++){ saveData.push((arr1).eq(i).val()); }; for(var j=0;j<arr2.length;j++){ saveData.push((arr2).eq(j).val()); }; }; function User(userId,userName,userPwd,memo,addDate,modifyDate,addUserId){ this.userId=saveData[1]; this.userName=saveData[2]; this.userPwd=saveData[3]; this.memo=saveData[4]; this.addDate=saveData[5]; this.modifyDate=saveData[6]; this.addUserId=saveData[7]; }; var user=new User(); var users=new Array(); users.push(user); $.ajax({ type: "post",//数据发送的方式(post 或者 get) url: "insert.do",//要发送的后台地址 data: {"user":JSON.stringify(users)}, dataType: "text",//后台处理后返回的数据格式 success:function (data){ alert(jQuery.parseJSON(data).msg); } }); } ``` 以上是前台的,接下去是后台的 ``` @ResponseBody @RequestMapping(value = "/insert.do", method = RequestMethod.POST) public Map insertUsers(HttpServletRequest request, @RequestBody String users) throws Exception{ users=URLDecoder.decode(users, "utf-8"); ObjectMapper mapper = new ObjectMapper(); //这里用了jackson,自己看看代码,很简洁的 JavaType javaType=mapper.getTypeFactory().constructParametricType(List.class,User.class); List<User> list = mapper.readValue(users, javaType); String msg=userService.insertUsers(list); Map map = new HashMap(); map.put("msg", msg); return map; } ``` 然后,后台的效果截图如下 ![图片说明](https://img-ask.csdn.net/upload/201612/18/1482069725_74209.png) 传到后台的Controller的,数据显示如下 ![图片说明](https://img-ask.csdn.net/upload/201612/18/1482069673_84864.png) 然后,进一步调试,出现错误如下 ![图片说明](https://img-ask.csdn.net/upload/201612/18/1482069716_404734.png) 请问,这个错误到底是什么原因造成的。是500错误。请高手帮助啊!正确的方法是什么呢?
python获取邮箱的内容后,怎么取到里面的验证码
# 连接到POP3服务器: server = poplib.POP3(pop3_server) # 可以打开或关闭调试信息: # server.set_debuglevel(1) # 可选:打印POP3服务器的欢迎文字: print(server.getwelcome().decode('utf-8')) # 身份认证: server.user(email) server.pass_(password) # stat()返回邮件数量和占用空间: print('Messages: %s. Size: %s' % server.stat()) # list()返回所有邮件的编号: resp, mails, octets = server.list() # 可以查看返回的列表类似[b'1 82923', b'2 2184', ...] # print(mails) # 获取最新一封邮件, 注意索引号从1开始: index = len(mails) resp, lines, octets = server.retr(index) # lines存储了邮件的原始文本的每一行, # 可以获得整个邮件的原始文本: msg_content = b'\r\n'.join(lines).decode('utf-8') # 稍后解析出邮件: msg = Parser().parsestr(msg_content) print_info(msg) ![图片说明](https://img-ask.csdn.net/upload/201912/05/1575552952_417417.png) 全部源码如下: # -*- coding: utf-8 -*- from email.parser import Parser from email.header import decode_header from email.utils import parseaddr import poplib import requests import json import re # 输入邮件地址, 口令和POP3服务器地址: email = "123456789@qq.com" password = "abcdefg" pop3_server = "pop.qq.com" # 文本邮件的内容也是str,还需要检测编码,否则,非UTF-8编码的邮件都无法正常显示 def guess_charset(msg): charset = msg.get_charset() if charset is None: content_type = msg.get('Content-Type', '').lower() pos = content_type.find('charset=') if pos >= 0: charset = content_type[pos + 8:].strip() return charset def decode_str(s): # decode_header()返回一个list 偷懒,只取了第一个元素 value, charset = decode_header(s)[0] if charset: value = value.decode(charset) return value def print_info(msg, indent=0): if indent == 0: for header in ['From', 'To', 'Subject']: value = msg.get(header, '') if value: if header=='Subject': value = decode_str(value) else: hdr, addr = parseaddr(value) name = decode_str(hdr) value = u'%s <%s>' % (name, addr) print('%s%s: %s' % (' ' * indent, header, value)) if (msg.is_multipart()): parts = msg.get_payload() for n, part in enumerate(parts): print('%spart %s' % (' ' * indent, n)) print('%s--------------------' % (' ' * indent)) print_info(part, indent + 1) else: content_type = msg.get_content_type() if content_type=='text/plain' or content_type=='text/html': content = msg.get_payload(decode=True) charset = guess_charset(msg) if charset: content = content.decode(charset) print('%sText: %s' % (' ' * indent, content + '...')) else: print('%sAttachment: %s' % (' ' * indent, content_type)) # 连接到POP3服务器: server = poplib.POP3(pop3_server) # 可以打开或关闭调试信息: # server.set_debuglevel(1) # 可选:打印POP3服务器的欢迎文字: print(server.getwelcome().decode('utf-8')) # 身份认证: server.user(email) server.pass_(password) # stat()返回邮件数量和占用空间: print('Messages: %s. Size: %s' % server.stat()) # list()返回所有邮件的编号: resp, mails, octets = server.list() # 可以查看返回的列表类似[b'1 82923', b'2 2184', ...] # print(mails) # 获取最新一封邮件, 注意索引号从1开始: index = len(mails) resp, lines, octets = server.retr(index) # lines存储了邮件的原始文本的每一行, # 可以获得整个邮件的原始文本: msg_content = b'\r\n'.join(lines).decode('utf-8')\ # 稍后解析出邮件: msg = Parser().parsestr(msg_content) print_info(msg)
报错:net.sf.json.JSONException
显示报错: ![图片说明](https://img-ask.csdn.net/upload/201705/02/1493697329_940817.png) 源代码: <% /*获取所有业务 */ String url="#url"; String param="#URL"; //地区编号 String html=""; //String temp=""; try{ String result=sendGet(url,param); result=URLDecoder.decode(result); //解析json数据 JSONObject jsonObject=JSONObject.fromObject(result); String info=jsonObject.getString("info"); JSONArray infoArray=JSONArray.fromObject(info); //拼接下面html数据 for(int i=0;i<infoArray.size();i++){ JSONObject oneObject=infoArray.getJSONObject(i); //temp=oneObject.getString("ACCEPT_USER_NAME"); //没有完成的业务就没有完成时间,需要先判断,否则报错: String finish_time=""; if(oneObject.containsKey("FINISH_TIME")){ finish_time="<script type='text/javascript'>showTime('"+oneObject.getString("FINISH_TIME")+"');</script>"; }else{ finish_time="处理中"; } String time_limit=""; if(oneObject.containsKey("TIME_LIMIT")){ time_limit="<script type='text/javascript'>showTime('"+oneObject.getString("TIME_LIMIT")+"');</script>"; }else{ time_limit="-"; } html+="<li><span class='span1'>"+oneObject.getString("RECEIVE_NUMBER")+"</span><span class='span2'><a title='"+oneObject.getString("APPLY_SUBJECT")+"'>"+oneObject.getString("APPLY_SUBJECT")+"</a></span><span class='span4'><a title='"+oneObject.getString("ORG_NAME")+"'>"+oneObject.getString("ORG_NAME")+"</a></span><span class='span4'>"+time_limit+"</span><span class='span4'>"+finish_time+"</span><span class='span3 yellow'>"+oneObject.getString("CURRENT_NODE_NAME")+"</span></li>"; } //out.print(html); }catch(Exception e){ out.print(e.toString()); } %> 麻烦高手看看是啥情况!
请问如何处理这样的binlog日志文件?
1.拿到手的是这样的一个log文件xxx.log: ``` orderPlan_test b'{"eventType":"INSERT","schemaName":"qixiao_test","rowAfter":{"update_time":1575291953000,"order_plan_id":63000036509,"create_time":1575291953000,"click_through_json":"{\\"landingPage\\":\\"http://www.baidu.com\\",\\"landingPageFlag\\":0,\\"appName\\":\\"tgnr120205\\",\\"account\\":\\"tgnr120205\\"}"},"tableName":"qx_order_plan_click_through","timestamp":1575291953000}' creative_test b'{"rowBefore":{"update_time":1575291971000,"create_time":1575291971000,"submit_time":1575291971000,"name":"\xe6\x88\x91\xe7\x9a\x84\xe5\x88\x9b\xe6\x84\x8f20191202210554","prod_status":0,"landing_page":"http://www.baidu.com","id":64000017479,"prod_fail_type":0,"landing_page_flag":0,"material_json":"{\\"name\\":\\"\xe6\x88\x91\xe7\x9a\x84\xe5\x88\x9b\xe6\x84\x8f20191202210554\\",\\"url\\":1585,\\"title\\":\\"\xe5\xb9\xbf\xe5\x91\x8a\xe6\x96\x87\xe6\xa1\x88123\\",\\"previewData\\":{\\"buttonTitle\\":\\"\xe4\xba\x86\xe8\xa7\xa3\xe8\xaf\xa6\xe6\x83\x85\\"},\\"events\\":{\\"impressionUrl\\":null,\\"clickUrl\\":null},\\"feedId\\":\\"1569467048\\",\\"clickThrough\\":{\\"landingPage\\":\\"http://www.baidu.com\\",\\"landingPageFlag\\":0,\\"appName\\":\\"tgnr120205\\",\\"account\\":\\"tgnr120205\\"}}","status":1},"eventType":"UPDATE","schemaName":"qixiao_test","rowAfter":{"update_time":1575291971000,"create_time":1575291971000,"submit_time":1575291971000,"name":"\xe6\x88\x91\xe7\x9a\x84\xe5\x88\x9b\xe6\x84\x8f20191202210554","prod_status":1,"landing_page":"http://www.baidu.com","id":64000017479,"prod_fail_type":0,"landing_page_flag":0,"material_json":"{\\"name\\":\\"\xe6\x88\x91\xe7\x9a\x84\xe5\x88\x9b\xe6\x84\x8f20191202210554\\",\\"url\\":1585,\\"title\\":\\"\xe5\xb9\xbf\xe5\x91\x8a\xe6\x96\x87\xe6\xa1\x88123\\",\\"previewData\\":{\\"buttonTitle\\":\\"\xe4\xba\x86\xe8\xa7\xa3\xe8\xaf\xa6\xe6\x83\x85\\"},\\"events\\":{\\"impressionUrl\\":null,\\"clickUrl\\":null},\\"feedId\\":\\"1569467048\\",\\"clickThrough\\":{\\"landingPage\\":\\"http://www.baidu.com\\",\\"landingPageFlag\\":0,\\"appName\\":\\"tgnr120205\\",\\"account\\":\\"tgnr120205\\"}}","status":1},"tableName":"qx_creative_staging","timestamp":1575291971000}' orderPlan_test b'{"eventType":"INSERT","schemaName":"qixiao_test","rowAfter":{"update_time":1575291953000,"order_plan_id":63000036509,"create_time":1575291953000,"target_json":"[{\\"id\\":32,\\"type\\":1,\\"isAnti\\":false},{\\"id\\":33,\\"type\\":1,\\"isAnti\\":false},{\\"id\\":1,\\"type\\":210,\\"isAnti\\":false},{\\"id\\":3,\\"type\\":210,\\"isAnti\\":false},{\\"id\\":4,\\"type\\":210,\\"isAnti\\":false},{\\"id\\":2,\\"type\\":210,\\"isAnti\\":false}]"},"tableName":"qx_order_plan_target","timestamp":1575291953000}' ……………… ``` 2.明显可见每隔一行是个json格式,我现在希望将这个解析成dic。如果手动赋值,显然是可行的。 ![图片说明](https://img-ask.csdn.net/upload/201912/03/1575363981_861834.png) 3.但是若果我用with open(filename,'r') 打开binlog文件,每一行结果是str格式,无法decode。请问该如何解决?![图片说明](https://img-ask.csdn.net/upload/201912/03/1575364128_83031.png) 4.如果用with open(filename,'r+b')打开还是不行 ![图片说明](https://img-ask.csdn.net/upload/201912/03/1575364716_97177.png) 5.1L回答的方法的问题是rowBefore,rowAfter里的中文编码,以及这两个key里嵌套的json格式不对
服务器断返回Boolean类型的数据到前台后, 解析数据, boolean型数据用不了了.
服务器端代码, 用一个map持有boolean型数据: [code="java"] jsonMaps = new HashMap<String, Boolean>(); jsonMaps.put("exist", true); jsonMaps.put("notExist", false); [/code] 返回json类型的数据到前台. 前台用EXT接收. [code="js"] success: function(response, options) { var responseText = Ext.util.JSON.decode(response.responseText); if(response.exist == true) { alert("exist");//不执行 } if(response.exist == "true") { alert("exist");//也不执行 } if(response.exist) { alert("exist");//还是不执行 } alert(responseText.exist == true);//弹出true } [/code] 请问, 这是为什么呢.. 我以为,那三个if最少会有一个执行的,事实上,一个没也执行..晕~~
爬取知乎信息报错--TypeError: string indices must be integers
``` ``` import requests import json import pymysql num=0 #设定爬取次数 user_all=[] #存放本次运行的用户 def get_url(url): #获取链接内容 header_info = { "User-Agent": 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/66.0.3359.139 Safari/537.36', } user_url =url response =requests.get(user_url, headers=header_info) data = response.content data = data.decode('utf-8') #设置字符集 return data def get_follower(userID): #解析内容,获取关注用户 list=[] url = 'https://www.zhihu.com/api/v4/members/'+userID+'/followees?' \ 'include=data%5B*%5D.answer_count%2Carticles_count%2Cgender%2Cfollower_count%' \ '2Cis_followed%2Cis_following%2Cbadge%5B%3F(type%3Dbest_answerer)%5D.topics&offset=0&limit=20' data = get_url(url) data = json.loads(data) print(data) for user in data: list.append(user['url_token']) return list get_follower('kaiqu') ``` 报错信息 TypeError Traceback (most recent call last) <ipython-input-22-0194a6f553cc> in <module> 32 33 ---> 34 get_follower('kaiqu') 35 36 <ipython-input-22-0194a6f553cc> in get_follower(userID) 28 print(data) 29 for user in data: ---> 30 list.append(user['url_token']) 31 return list 32 TypeError: string indices must be integers
python在shell中运行正常,但在windows中经常报错
我写了一个获取网页信息的文件,在shell中测试,运行情况良好, 但是直接双击打开py文件,则经常闪退。 以下是代码。这种情况我不是很了解,求帮助。 ``` # -*- coding: utf-8 -*- import urllib2 import urllib import re import thread import time import json #----------加载处理Steam市场-------------- class Spider_Model: def __init__(self): self.enable = False self.myUrl = "http://steamcommunity.com/market/recent?country=CN&language=schinese&currency=1" self.data = {"country":"CN", "language":"schinese", "currency":"1"} def getLastOn(self,page): #print(page) #page = page.decode("utf-8") #找出所有的class="market_listing_item_name_link"的a #找出所有的class="market_listing_game_name"的span #找出所有的class="market_listing_price market_listing_price_with_fee"的span Commodity_names = re.findall('<a class="market_listing_item_name_link".*?>(.*?)</a>',page,re.S) Commodity_games = re.findall('<span.*?class="market_listing_game_name">(.*?)</span>',page,re.S) Commodity_prices = re.findall('<span.*?class="market_listing_price market_listing_price_with_fee">(.*?)</span>',page,re.S) #曾用来统计获取到的数据数量 #print len(Commodity_names) #print len(Commodity_games) #print len(Commodity_prices) items = [] for i in range(0,10): Commodity_prices[i] = Commodity_prices[i].replace("&#36;","$") #print[Commodity_prices[i]] item = [Commodity_names[i],Commodity_games[i],Commodity_prices[i]] items.append(item) print items[i][0]+"\n"+items[i][1]+items[i][2]+"\n" return items #访问地址后返回的是Json文件 def request_ajax_data(self): req = urllib2.Request(self.myUrl) #伪装成浏览器访问 req.add_header('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8') req.add_header('X-Requested-With','XMLHttpRequest') req.add_header('User-Agent','Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/27.0.1453.116') params = urllib.urlencode(self.data) #print(params) response = urllib2.urlopen(req, params) jsonText = response.read() #使原编码改为utf-8编码(中文太恶心了) unicodePage = jsonText.decode("utf-8") return unicodePage #解析Json文件 def parseJson(self,jsonText): j = json.loads(jsonText) page = j["results_html"] #print(page) return page def start(self): self.enable = True while self.enable: self.getLastOn(self.parseJson(self.request_ajax_data())) print('========================^_^============================') myInput = raw_input() if myInput == 'q': self.enable = False break #------------程序入口处--------------- print u''' --------------------------------------- 程序:steam市场 语言:Pythom 2.7 版本:1.0 作者:Cy 操作:输入‘q’退出,按下回车获取最新上架资讯 功能:获取steam市场上最新上架的信息 --------------------------------------- ''' print u'~~~~' print u'请按下回车浏览即时steam最新上架:' myInput = raw_input(' ') myModel = Spider_Model() #print(myModel.GetLastOn(myUrl)) #myModel.request_ajax_data(myUrl,) #print(myModel.request_ajax_data()) #f = open('steam.json','w+') #f.write(myModel.request_ajax_data()) #f.close() #tt = myModel.request_ajax_data() #page = myModel.parseJson(tt) #myModel.getLastOn(page) myModel.start() print u'谢谢使用!' #market.js/line:948&992 ```
jQuery POST请求参数解析出错
index.jsp中构造param: function hello() { alert("hello"); var mydata = [{"word" : "12345"}]; alert(JSON.stringify(mydata)); $.post('hello', JSON.stringify(mydata), function(text, status) { alert(text); }); } 请求接收端的代码如下: @Controller public class HelloWorldController { @RequestMapping(value = "/hello",method = RequestMethod.POST) public @ResponseBody HttpSayHelloTestRsp sayHello( @RequestBody String req) throws UnsupportedEncodingException { String decodeStr = URLDecoder.decode(req,"utf-8"); System.out.println("-----------------收到Hello请求\r\n"+decodeStr ); return null; } } 但是在HelloWorldController端接收到的decodeStr是[{"word" : "12345"}]= 而且,在firfox浏览器的控制台界面,看到传输的参数是:[{"word" : "12345"}]: 请问各位大神,这是什么情况?
请问awk和python中如何显示当天产生的日志?
#coding=utf-8 import os import json import httplib import codecs LogFile='/etc/httpd/logs/access_log' #日志 logMess='/tmp/acc.log' if os.path.isfile(logMess): os.system('cp /dev/null %s'% logMess) file=codecs.open(logMess,'w+',encoding='utf-8') def cmd(cmd): return os.popen(cmd).readlines() ''' def getIp(ip): return json.loads(os.popen("/usr/bin/curl http://ip.taobao.com/service/getIpInfo.php?ip=%s" % ip).readline())['data'] ''' conn = httplib.HTTPConnection('ip.taobao.com') def getIpCountry(ip): conn.request('GET','/service/getIpInfo.php?ip=%s' % ip) r1=conn.getresponse() if r1.status == 200: #return json.loads(r1.read())['data'] return json.loads(r1.read().decode())['data'] else: return "Error" #将access.log文件进行分析,并转为python数组 file.write(u"字段说明:ip 访问次数据 ip国家 城市的 isp号 省份 所在地区\n") ipDb=[] for i in cmd('''/usr/bin/awk '{print $1}' %s |sort |uniq -c''' % LogFile): ip = i.strip().split(' ') ipDb.append(ip) #通过taobao 提供接口分析ip地址来源 for i in ipDb: _tmpD=getIpCountry(i[1]) #格式说明:ip 访问次数据 ip国家 城市的 isp号 省份 所在地区 if _tmpD['city'] == unicode('唐山市', "utf-8"): print i out="%s%s%s%s%s%s%s"%(i[1].ljust(20),i[0].ljust(10),_tmpD['country'].ljust(20),_tmpD['city'].ljust(16),_tmpD['isp_id'].ljust(16),_tmpD['region'].ljust(16),_tmpD['area'].ljust(16)) print (out) file.write("%s\n"%out) conn.close() file.close() 我想显示当天的日志,怎么做?
spring security和spring oauth结合后 spring security配置不管用了
> spring security ``` @Configuration @EnableResourceServer public class AppWebSecurityConfigurerAdapter extends WebSecurityConfigurerAdapter { @Autowired private ZuulProperties zuulProperties; @Autowired private AuthenticationSuccessHandler appAuthenticationSuccessHandler; @Autowired private AuthenticationFailureHandler appAuthenticationFailureHandler; @Autowired private AccessDeniedHandler appAccessDeniedHandler; @Bean @Override public AuthenticationManager authenticationManagerBean() throws Exception { AuthenticationManager manager = super.authenticationManagerBean(); return manager; } @Override protected void configure(HttpSecurity http) throws Exception { http .authorizeRequests() .antMatchers(HttpMethod.GET,zuulProperties.getAuth().toGetAdapter()) .permitAll() .and() .authorizeRequests() .antMatchers(HttpMethod.POST,zuulProperties.getAuth().toPostAdapter()) .permitAll() .and() .authorizeRequests() .anyRequest() .authenticated() .and() .exceptionHandling().accessDeniedHandler(appAccessDeniedHandler) .and() .csrf().disable(); } ``` > spring oauth相关 ``` @Configuration @EnableAuthorizationServer public class AppAuthorizationServerConfig extends AuthorizationServerConfigurerAdapter { @Autowired private final AuthenticationManager authenticationManager; @Autowired private UserDetailsService userDetailsService; @Autowired private ZuulProperties zuulProperties; @Autowired private TokenStore tokenStore ; @Autowired(required = false) private JwtAccessTokenConverter jwtAccessTokenConverter; @Autowired(required = false) private TokenEnhancer jwtTokenEnhancer; @Autowired private PasswordEncoder passwordEncoder; public AppAuthorizationServerConfig(AuthenticationManager authenticationManager) { this.authenticationManager = authenticationManager; } @Override public void configure(ClientDetailsServiceConfigurer clients) throws Exception { InMemoryClientDetailsServiceBuilder builder = clients.inMemory(); OAuth2ClientProperties[] clientProperties = zuulProperties.getOauth().getClients(); if(ArrayUtils.isNotEmpty(zuulProperties.getOauth().getClients())) { for (OAuth2ClientProperties oAuth2ClientProperties : clientProperties) { builder.withClient(oAuth2ClientProperties.getClientId()) .secret(oAuth2ClientProperties.getClientSecret()) //token有效时间 .accessTokenValiditySeconds(oAuth2ClientProperties.getAccessTokenValiditySeconds()) //验证模式 .authorizedGrantTypes("password","authorization_code","client_credentials","implicit","refresh_token") //刷新时间 .refreshTokenValiditySeconds(3600*24*100) //跳转地址 .redirectUris("ws.28ph.cn") //权限 .scopes("all"); } } } @Override public void configure(AuthorizationServerEndpointsConfigurer endpoints) throws Exception { endpoints.authenticationManager(authenticationManager) .tokenStore(tokenStore) .userDetailsService(userDetailsService) .reuseRefreshTokens(true); if(jwtAccessTokenConverter != null && jwtTokenEnhancer!=null) { TokenEnhancerChain enhancerChain = new TokenEnhancerChain(); List<TokenEnhancer> tokenEnhancers = new ArrayList<>(); tokenEnhancers.add(jwtTokenEnhancer); tokenEnhancers.add(jwtAccessTokenConverter); enhancerChain.setTokenEnhancers(tokenEnhancers); endpoints .tokenEnhancer(enhancerChain) .accessTokenConverter(jwtAccessTokenConverter); } } @Override public void configure(AuthorizationServerSecurityConfigurer security) throws Exception { security.allowFormAuthenticationForClients() .passwordEncoder(passwordEncoder) .tokenKeyAccess("permitAll()") .checkTokenAccess("isAuthenticated()"); } } ``` 问题的产生:我在spring security配置了几个不需要拦截的uri,但是加入spring oauth 全部被拦截了,如果删掉@EnableResourceServer会出现 发出来的token 认证不了url的问题。。 然后我想大不了不用spring oauth 自带的发token方式。然后我在spring security的成功handler上下发token ,以下是代码 ``` /** * 认证成功跳转 * @author w4837 * */ @Component(value = "AppAuthenticationSuccessHandler") @Slf4j public class AppAuthenticationSuccessHandler extends SavedRequestAwareAuthenticationSuccessHandler { @Autowired private ObjectMapper objectMapper; @Autowired private ClientDetailsService clientDetailsService; @Autowired private AuthorizationServerTokenServices authorizationServerTokenServices; @Override public void onAuthenticationSuccess(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Authentication authentication) throws IOException, ServletException { log.info("登陆成功"); String header = httpServletRequest.getHeader("Authorization"); //请求头包含Authorization 并且以"Basic "开始 if (header == null || !header.startsWith("Basic ")) { throw new UnapprovedClientAuthenticationException("请求头中无Authorization信息"); } try { String[] tokens = extractAndDecodeHeader(header, httpServletRequest); assert tokens.length == 2; String clientId = tokens[0]; String clientSecret = tokens[1]; ClientDetails clientDetails = clientDetailsService.loadClientByClientId(clientId); if(clientDetails == null) { throw new UnapprovedClientAuthenticationException("clientId:"+clientId+"对应的信息不存在。"); }else if(!StringUtils.equals(clientSecret, clientDetails.getClientSecret())) { throw new UnapprovedClientAuthenticationException("clientId:"+clientId+"对应的信息不匹配。"); } @SuppressWarnings("unchecked") TokenRequest tokenRequest = new TokenRequest(MapUtils.EMPTY_MAP, clientId, clientDetails.getScope(),"custom"); OAuth2Request auth2Request = tokenRequest.createOAuth2Request(clientDetails); OAuth2Authentication auth2Authentication = new OAuth2Authentication(auth2Request, authentication); OAuth2AccessToken createAccessToken = authorizationServerTokenServices.createAccessToken(auth2Authentication); // 判断需要的返回类型 httpServletResponse.setContentType(ZuulAppConstant.CONTENT_TYPE_JSON); httpServletResponse.getWriter().write(objectMapper.writeValueAsString(createAccessToken)); } catch (Exception e) { log.error(e.getMessage()); } } /** * 解析header中编码后的数据 * * @param header * @param request * @return * @throws IOException */ private String[] extractAndDecodeHeader(String header, HttpServletRequest request) throws IOException { byte[] base64Token = header.substring(6).getBytes("UTF-8"); byte[] decoded; try { decoded = Base64.decode(base64Token); } catch (IllegalArgumentException e) { throw new BadCredentialsException("Failed to decode basic authentication token"); } String token = new String(decoded, "UTF-8"); int delim = token.indexOf(":"); if (delim == -1) { throw new BadCredentialsException("Invalid basic authentication token"); } return new String[] { token.substring(0, delim), token.substring(delim + 1) }; } ``` 结果 启动还是报循环依赖的错误 ``` *************************** APPLICATION FAILED TO START *************************** Description: The dependencies of some of the beans in the application context form a cycle: ┌─────┐ | appAuthorizationServerConfig defined in file [F:\yulece_aike_ideaword\app-management\app-management-zuul\target\classes\com\yulece\app\management\zuul\authorization\AppAuthorizationServerConfig.class] ↑ ↓ | appWebSecurityConfigurerAdapter (field private org.springframework.security.web.authentication.AuthenticationSuccessHandler com.yulece.app.management.zuul.authorization.AppWebSecurityConfigurerAdapter.appAuthenticationSuccessHandler) ↑ ↓ | AppAuthenticationSuccessHandler (field private org.springframework.security.oauth2.provider.token.AuthorizationServerTokenServices com.yulece.app.management.zuul.authorization.handler.AppAuthenticationSuccessHandler.defaultAuthorizationServerTokenServices) ↑ ↓ | org.springframework.security.oauth2.config.annotation.web.configuration.AuthorizationServerEndpointsConfiguration (field private java.util.List org.springframework.security.oauth2.config.annotation.web.configuration.AuthorizationServerEndpointsConfiguration.configurers) └─────┘ ```
Extjs如何获取后台方法返回的值然后前台接收值再把此值放入action url里进行load加载
前台://把上传的 文件发送到相应Action function upload(){ var tml = document.getElementById("fileId"); if(tml.value == ''){ Ext.MessageBox.alert('提示','请选择需要上传文件'); return; } Ext.Ajax.request({ url: '../manager/print!excelUpload.action', form: Ext.fly('uploadForm'), waitMsg: "正在保存数据...", headers: {'Content-type':'multipart/form-data'}, isUpload: true, success: function(response) { var jsonObj = Ext.decode(response.responseText); store.load(); }, failure: function (response) { if(Ext.util.JSON.encode(response.status)==0){ Ext.MessageBox.alert('提示','无法连接到服务器,请检查网络是否正常'); } else { Ext.MessageBox.alert('提示','操作出现异常,请与系统管理员联系'); } } }); 这是后台: public String excelUpload() throws FileNotFoundException, IOException { //获取当前系统时间时分秒 SimpleDateFormat st = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); String time = st.format(new Date()); //获取文件路径转换输入流 InputStream is =new FileInputStream(filenPathname); //解析出来的 字符格式 WorkbookSettings workbookSettings = new WorkbookSettings(); workbookSettings.setEncoding("GBK"); try { //创建工作薄对象 (Excel对象) Workbook work =Workbook.getWorkbook(is,workbookSettings); //获取工作薄中表 Sheet sheet =work.getSheet(0); int rows = sheet.getRows();//获取总行数、 int cell =sheet.getColumns();//获取总列数 System.out.println(rows); System.out.println(cell); //循环所有行数 for (int i = 1; i < rows; i++) { PtUploadOrderTmp pt= new PtUploadOrderTmp(); System.out.println("------------" + i); String[] str = new String[cell]; //循环行下的每一列的值 //把每一行每一列的值循环出来 pt.setWaybillNo(sheet.getCell(0, i).getContents()); pt.setSenderAddress(sheet.getCell(1, i).getContents()); pt.setSenderCompany(sheet.getCell(2, i).getContents()); pt.setReceiverName(sheet.getCell(3, i).getContents()); pt.setReceiverPhone(sheet.getCell(4, i).getContents()); pt.setGoods(sheet.getCell(5, i).getContents()); pt.setPsc(BigDecimal.ONE); //件数 6 pt.setWeight(Double.valueOf(sheet.getCell(7, i).getContents()));//重量 pt.setVolume(BigDecimal.ZERO);//体积 8 pt.setCod(Double.valueOf(sheet.getCell(9, i).getContents()));//代收货款 pt.setPayment(sheet.getCell(10, i).getContents());//付款方式 try { pt.setSendDate(new SimpleDateFormat("yyyy-MM-dd").parse(sheet.getCell(11, i).getContents())); } catch (ParseException e) { // TODO Auto-generated catch block e.printStackTrace(); }//发送时间 pt.setIsPrint(sheet.getCell(12, i).getContents().equals("是"));//是否打印 pt.setIsUpload(sheet.getCell(13, i).getContents().equals("是"));//是否上传 pt.setRemark1(sheet.getCell(14, i).getContents());//备注 pt.setBatchNo(time); //批次号 oderService.save(pt); } } catch (BiffException e) { // TODO Auto-generated catch block e.printStackTrace(); } return ajaxJson(time); }
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私有的数
win10系统安装教程(U盘PE+UEFI安装)
一、准备工作 u盘,电脑一台,win10原版镜像(msdn官网) 二、下载wepe工具箱  极力推荐微pe(微pe官方下载) 下载64位的win10 pe,使用工具箱制作启动U盘打开软件,   选择安装到U盘(按照操作无需更改) 三、重启进入pe系统   1、关机后,将U盘插入电脑 2、按下电源后,按住F12进入启动项选择(技嘉主板是F12)     选择需要启
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小人工智障。 思路可以运用在不同地方,主要介绍的是思路。
Nginx 软件层面加强Nginx性能优化的面试问答和解决方案
Nginx 软件层面加强Nginx性能优化的面试问答和解决方案 去年我去爱卡汽车面试PHP,一轮和二轮面的都不错,在三轮面到Nginx的时候很多问题当时不知道怎么回答,确实没有深入学习过,花了一段时间的学习,终于能解答Nginx高性能优化的问题了,10月24号为了获得程序员勋章,发布了半个优化笔记,浏览到了1000+,受到这个鼓舞,我抽时间在仔细整理下关于Nginx性能优化的问题,我们从软件说起。...
【管理系统课程设计】美少女手把手教你后台管理
【文章后台管理系统】URL设计与建模分析+项目源码+运行界面 栏目管理、文章列表、用户管理、角色管理、权限管理模块(文章最后附有源码) 1. 这是一个什么系统? 1.1 学习后台管理系统的原因 随着时代的变迁,现如今各大云服务平台横空出世,市面上有许多如学生信息系统、图书阅读系统、停车场管理系统等的管理系统,而本人家里就有人在用烟草销售系统,直接在网上完成挑选、购买与提交收货点,方便又快捷。 试想,若没有烟草销售系统,本人家人想要购买烟草,还要独自前往药...
11月19日科技资讯|华为明日发布鸿蒙整体战略;京东宣告全面向技术转型;Kotlin 1.3.60 发布
「极客头条」—— 技术人员的新闻圈! CSDN 的读者朋友们早上好哇,「极客头条」来啦,快来看今天都有哪些值得我们技术人关注的重要新闻吧。扫描上方二维码进入 CSDN App 可以收听御姐萌妹 Style 的人工版音频哟。 一分钟速览新闻点! 6G 专家组成员:速率是 5G 的 10 至 100 倍,预计 2030 年商用 雷军:很多人多次劝我放弃WPS,能坚持下来并不是纯粹的商业决定 ...
C语言魔塔游戏
很早就很想写这个,今天终于写完了。 游戏截图: 编译环境: VS2017 游戏需要一些图片,如果有想要的或者对游戏有什么看法的可以加我的QQ 2985486630 讨论,如果暂时没有回应,可以在博客下方留言,到时候我会看到。 下面我来介绍一下游戏的主要功能和实现方式 首先是玩家的定义,使用结构体,这个名字是可以自己改变的 struct gamerole { char n
化繁为简 - 腾讯计费高一致TDXA的实践之路
导语:腾讯计费是孵化于支撑腾讯内部业务千亿级营收的互联网计费平台,在如此庞大的业务体量下,腾讯计费要支撑业务的快速增长,同时还要保证每笔交易不错账。采用最终一致性或离线补...
Python爬虫爬取淘宝,京东商品信息
小编是一个理科生,不善长说一些废话。简单介绍下原理然后直接上代码。 使用的工具(Python+pycharm2019.3+selenium+xpath+chromedriver)其中要使用pycharm也可以私聊我selenium是一个框架可以通过pip下载 pip install selenium -i https://pypi.tuna.tsinghua.edu.cn/simple/ 
Java学习笔记(七十二)—— Cookie
概述 会话技术: 会话:一次会话中包含多次请求和响应 一次会话:浏览器第一次给服务器发送资源请求,会话建立,直到有一方断开为止 功能:在一次会话的范围内的多次请求间,共享数据 方式: 客户端会话技术:Cookie,把数据存储到客户端 服务器端会话技术:Session,把数据存储到服务器端 Cookie 概念:客户端会话技术,将数据存储到客户端 快速入门: 使用步骤: 创建C
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
Java工作4年来应聘要16K最后没要,细节如下。。。
前奏: 今天2B哥和大家分享一位前几天面试的一位应聘者,工作4年26岁,统招本科。 以下就是他的简历和面试情况。 基本情况: 专业技能: 1、&nbsp;熟悉Sping了解SpringMVC、SpringBoot、Mybatis等框架、了解SpringCloud微服务 2、&nbsp;熟悉常用项目管理工具:SVN、GIT、MAVEN、Jenkins 3、&nbsp;熟悉Nginx、tomca
2020年,冯唐49岁:我给20、30岁IT职场年轻人的建议
点击“技术领导力”关注∆  每天早上8:30推送 作者| Mr.K   编辑| Emma 来源| 技术领导力(ID:jishulingdaoli) 前天的推文《冯唐:职场人35岁以后,方法论比经验重要》,收到了不少读者的反馈,觉得挺受启发。其实,冯唐写了不少关于职场方面的文章,都挺不错的。可惜大家只记住了“春风十里不如你”、“如何避免成为油腻腻的中年人”等不那么正经的文章。 本文整理了冯
程序员该看的几部电影
##1、骇客帝国(1999) 概念:在线/离线,递归,循环,矩阵等 剧情简介: 不久的将来,网络黑客尼奥对这个看似正常的现实世界产生了怀疑。 他结识了黑客崔妮蒂,并见到了黑客组织的首领墨菲斯。 墨菲斯告诉他,现实世界其实是由一个名叫“母体”的计算机人工智能系统控制,人们就像他们饲养的动物,没有自由和思想,而尼奥就是能够拯救人类的救世主。 可是,救赎之路从来都不会一帆风顺,到底哪里才是真实的世界?
作为一个程序员,CPU的这些硬核知识你必须会!
CPU对每个程序员来说,是个既熟悉又陌生的东西? 如果你只知道CPU是中央处理器的话,那可能对你并没有什么用,那么作为程序员的我们,必须要搞懂的就是CPU这家伙是如何运行的,尤其要搞懂它里面的寄存器是怎么一回事,因为这将让你从底层明白程序的运行机制。 随我一起,来好好认识下CPU这货吧 把CPU掰开来看 对于CPU来说,我们首先就要搞明白它是怎么回事,也就是它的内部构造,当然,CPU那么牛的一个东
@程序员,如何花式构建线程?
作者 |曾建责编 | 郭芮出品 | CSDN(ID:CSDNnews)在项目和业务的开发中,我们难免要经常使用线程来进行业务处理,使用线程可以保证我们的业务在相互处理之间可以保证原子性...
破14亿,Python分析我国存在哪些人口危机!
2020年1月17日,国家统计局发布了2019年国民经济报告,报告中指出我国人口突破14亿。 猪哥的朋友圈被14亿人口刷屏,但是很多人并没有看到我国复杂的人口问题:老龄化、男女比例失衡、生育率下降、人口红利下降等。 今天我们就来分析一下我们国家的人口数据吧! 一、背景 1.人口突破14亿 2020年1月17日,国家统计局发布了 2019年国民经济报告 ,报告中指出:年末中国大陆总人口(包括31个
强烈推荐10本程序员在家读的书
很遗憾,这个鼠年春节注定是刻骨铭心的,新型冠状病毒让每个人的神经都是紧绷的。那些处在武汉的白衣天使们,尤其值得我们的尊敬。而我们这些窝在家里的程序员,能不外出就不外出,就是对社会做出的最大的贡献。 有些读者私下问我,窝了几天,有点颓丧,能否推荐几本书在家里看看。我花了一天的时间,挑选了 10 本我最喜欢的书,你可以挑选感兴趣的来读一读。读书不仅可以平复恐惧的压力,还可以对未来充满希望,毕竟苦难终
Linux自学篇——linux命令英文全称及解释
man: Manual 意思是手册,可以用这个命令查询其他命令的用法。 pwd:Print working directory 显示当前目录 su:Swith user 切换用户,切换到root用户 cd:Change directory 切换目录 ls:List files 列出目录下的文件 ps:Process Status 进程状态 mk
Python实战:抓肺炎疫情实时数据,画2019-nCoV疫情地图
文章目录1. 前言2. 数据下载3. 数据处理4. 数据可视化 1. 前言 今天,群里白垩老师问如何用python画武汉肺炎疫情地图。白垩老师是研究海洋生态与地球生物的学者,国家重点实验室成员,于不惑之年学习python,实为我等学习楷模。先前我并没有关注武汉肺炎的具体数据,也没有画过类似的数据分布图。于是就拿了两个小时,专门研究了一下,遂成此文。 2月6日追记:本文发布后,腾讯的数据源多次变更u
智力题(程序员面试经典)
NO.1  有20瓶药丸,其中19瓶装有1克/粒的药丸,余下一瓶装有1.1克/粒的药丸。给你一台称重精准的天平,怎么找出比较重的那瓶药丸?天平只能用一次。 解法 有时候,严格的限制条件有可能反倒是解题的线索。在这个问题中,限制条件是天平只能用一次。 因为天平只能用一次,我们也得以知道一个有趣的事实:一次必须同时称很多药丸,其实更准确地说,是必须从19瓶拿出药丸进行称重。否则,如果跳过两瓶或更多瓶药
在家远程办公效率低?那你一定要收好这个「在家办公」神器!
相信大家都已经收到国务院延长春节假期的消息,接下来,在家远程办公可能将会持续一段时间。 但是问题来了。远程办公不是人在电脑前就当坐班了,相反,对于沟通效率,文件协作,以及信息安全都有着极高的要求。有着非常多的挑战,比如: 1在异地互相不见面的会议上,如何提高沟通效率? 2文件之间的来往反馈如何做到及时性?如何保证信息安全? 3如何规划安排每天工作,以及如何进行成果验收? ......
作为一个程序员,内存和磁盘的这些事情,你不得不知道啊!!!
截止目前,我已经分享了如下几篇文章: 一个程序在计算机中是如何运行的?超级干货!!! 作为一个程序员,CPU的这些硬核知识你必须会! 作为一个程序员,内存的这些硬核知识你必须懂! 这些知识可以说是我们之前都不太重视的基础知识,可能大家在上大学的时候都学习过了,但是嘞,当时由于老师讲解的没那么有趣,又加上这些知识本身就比较枯燥,所以嘞,大家当初几乎等于没学。 再说啦,学习这些,也看不出来有什么用啊!
2020年的1月,我辞掉了我的第一份工作
其实,这篇文章,我应该早点写的,毕竟现在已经2月份了。不过一些其它原因,或者是我的惰性、还有一些迷茫的念头,让自己迟迟没有试着写一点东西,记录下,或者说是总结下自己前3年的工作上的经历、学习的过程。 我自己知道的,在写自己的博客方面,我的文笔很一般,非技术类的文章不想去写;另外我又是一个还比较热衷于技术的人,而平常复杂一点的东西,如果想写文章写的清楚点,是需要足够...
别低估自己的直觉,也别高估自己的智商
所有群全部吵翻天,朋友圈全部沦陷,公众号疯狂转发。这两周没怎么发原创,只发新闻,可能有人注意到了。我不是懒,是文章写了却没发,因为大家的关注力始终在这次的疫情上面,发了也没人看。当然,我...
Java坑人面试题系列: 包装类(中级难度)
Java Magazine上面有一个专门坑人的面试题系列: https://blogs.oracle.com/javamagazine/quiz-2。 这些问题的设计宗旨,主要是测试面试者对Java语言的了解程度,而不是为了用弯弯绕绕的手段把面试者搞蒙。 如果你看过往期的问题,就会发现每一个都不简单。 这些试题模拟了认证考试中的一些难题。 而 “中级(intermediate)” 和 “高级(ad
Spring Boot 2.x基础教程:使用JdbcTemplate访问MySQL数据库
在第2章节中,我们介绍了如何通过Spring Boot来实现HTTP接口,以及围绕HTTP接口相关的单元测试、文档生成等实用技能。但是,这些内容还不足以帮助我们构建一个动态应用的服务端程序。不论我们是要做App、小程序、还是传统的Web站点,对于用户的信息、相关业务的内容,通常都需要对其进行存储,而不是像第2章节中那样,把用户信息存储在内存中(重启就丢了!)。 对于信息的存储,现在已经有非常非常多...
基于Python的人脸自动戴口罩系统
目录 1、项目背景 2、页面设计 3、器官识别 4、退出系统 1、项目背景 2019年新型冠状病毒感染的肺炎疫情发生以来,牵动人心,举国哀痛,口罩、酒精、消毒液奇货可居。 抢不到口罩,怎么办?作为技术人今天分享如何使用Python实现自动戴口罩系统,来安慰自己,系统效果如下所示: 本系统的实现原理是借助 Dlib模块的Landmark人脸68个关键点检测库轻松识别出人脸五官
这个世界上人真的分三六九等,你信吗?
偶然间,在知乎上看到一个问题 一时间,勾起了我深深的回忆。 以前在厂里打过两次工,做过家教,干过辅导班,做过中介。零下几度的晚上,贴过广告,满脸、满手地长冻疮。 再回首那段岁月,虽然苦,但让我学会了坚持和忍耐。让我明白了,在这个世界上,无论环境多么的恶劣,只要心存希望,星星之火,亦可燎原。 下文是原回答,希望能对你能有所启发。 如果我说,这个世界上人真的分三六九等,...
相关热词 c# 为空 判断 委托 c#记事本颜色 c# 系统默认声音 js中调用c#方法参数 c#引入dll文件报错 c#根据名称实例化 c#从邮件服务器获取邮件 c# 保存文件夹 c#代码打包引用 c# 压缩效率
立即提问