文章目录
0 基础知识
table类型的表格网页结构
read_html()函数
1 快速抓取法
2 完整爬虫抓取法
3 小结
常见的各种官网都有这样一种情况:
网站中很多表格 ,我们想对这些表格进行整理汇总 、或者是筛选 ,或者是处理分析 。
于是我们需要考虑:如何将网页表格数据使用python保存为Excel文件?
如果需要抓的表格很少或只需要抓一次,那么推荐快速抓取法 [引文1]
。
如果页数比较多,推荐完整爬虫抓取法 [引文2]
。解析函数用了BeautifulSoup和css选择器,这种方法定位提取表格所在的id为#myTable04的table代码段,更为准确。
0 基础知识
table类型的表格网页结构
一般情况下,网页的表格数据主要是在标签中,类型的表格网页结构大致如下:
...
...
...
...
...
...
...
...
...
...
...
简单解释上文出现的几种标签含义:
: 定义表格
: 定义表格的页眉
: 定义表格的主体
: 定义表格的行
: 定义表格的表头
: 定义表格单元
使用pandas的read_html()
方法就可以读取标签中的内容。
read_html()函数
pandas. read_html( io,
match= '.+' ,
flavor= None ,
header= None ,
index_col= None ,
skiprows= None ,
attrs= None ,
parse_dates= False ,
tupleize_cols= None ,
thousands= ', ' ,
encoding= None ,
decimal= '.' ,
converters= None ,
na_values= None ,
keep_default_na= True ,
displayed_only= True )
常用的参数:
io:可以是url、html文本、本地文件等
flavor:解析器;
header:标题行;
skiprows:跳过的行;
attrs:属性,比如 attrs = {‘id’: ‘table’};
parse_dates:解析日期
注意:返回的结果是DataFrame 组成的list 。
1 快速抓取法
1.1 思路
这里以NBA Player Salaries - 2020-2021为例,具体步骤如下:
step0:查看网页元素。 在目标网页中,右键“审查元素”,发现是类型的网页结构,可以用read_html()
抓取。
step1:确定抓取数据量和网页类型。 表数据共14页,数据量不大;且1-14页的网址只有page的变化,属于静态网页。
step2:代码思路。 核心思路:使用pandas库中的read_html()
函数,采用快速抓取法 完成网页表格数据的收集。建立空白DataFrame结构 - 建立爬取网址合集urls - 依次爬取每一页的表格数据并append - 导出最终数据到csv。
1.2 代码
import pandas as pd
df= pd. DataFrame( )
url_ori= 'http://www.espn.com/nba/salaries/_/page/'
urls= [ url_ori+ str ( i) for i in range ( 1 , 15 ) ]
for i, url in enumerate ( urls) :
print ( i+ 1 )
df= df. append( pd. read_html( url) , ignore_index= True )
df. shape
df= df[ df[ 0 ] != 'RK' ] [ [ 1 , 2 , 3 ] ] . reset_index( drop= True )
df. to_csv( r'd:/desktop/NBA Player Salaries-2020-2021.csv' , header= [ 'NAME' , 'TEAM' , 'SALARY' ] , index= False )
2 完整爬虫抓取法
2.1 思路
这里以中商情报网为例,具体步骤如下:
step0:查看网页元素。 在目标网页中,右键“审查元素”,发现是类型的网页结构,可以用read_html()
抓取。
step1:确定抓取数据量和网页类型。 表数据共208页,数据量较大;且1-208页的网址只有pageNum的变化,属于静态网页。
step2:代码思路。 核心思路:使用pandas库中的read_html()
函数,采用完整爬虫抓取法 完成网页表格数据的收集。将整个爬取分为网页提取、内容解析、数据存储等步骤,依次建立相应的函数 - 主函数建立空白DataFrame结构 - 依次爬取每一页的表格数据并append - 导出最终数据到csv。
2.2 代码
import pandas as pd
import requests
from bs4 import BeautifulSoup
from lxml import etree
from urllib. parse import urlencode
import time
start_time = time. time( )
def get_one_page ( i) :
try :
headers = { 'User-Agent' : 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/66.0.3359.181 Safari/537.36' }
paras = {
'reportTime' : '2017-12-31' ,
'pageNum' : i
}
url = 'http://s.askci.com/stock/a/?' + urlencode( paras)
response = requests. get( url, headers = headers)
if response. status_code == 200 :
return response. text
return None
except RequestException:
print ( '爬取失败' )
def parse_one_page ( html) :
soup = BeautifulSoup( html, 'lxml' )
content = soup. select( '#myTable04' ) [ 0 ]
tbl = pd. read_html( content. prettify( ) , header = 0 ) [ 0 ]
tbl. rename( columns = { '序号' : 'serial_number' ,
'股票代码' : 'stock_code' ,
'股票简称' : 'stock_abbre' ,
'公司名称' : 'company_name' ,
'省份' : 'province' ,
'城市' : 'city' ,
'主营业务收入(201712)' : 'main_bussiness_income' ,
'净利润(201712)' : 'net_profit' ,
'员工人数' : 'employees' ,
'上市日期' : 'listing_date' ,
'招股书' : 'zhaogushu' ,
'公司财报' : 'financial_report' ,
'行业分类' : 'industry_classification' ,
'产品类型' : 'industry_type' ,
'主营业务' : 'main_business' } , inplace = True )
return tbl
def write_to_csv ( df) :
df. to_csv( r'd:\desktop\test.csv' , index= False )
def main ( page) :
df= pd. DataFrame( )
for i in range ( 1 , page) :
html = get_one_page( i)
tbl = parse_one_page( html)
df= df. append( tbl)
write_to_csv( df)
if __name__== '__main__' :
n= 3
main( n+ 1 )
endtime = time. time( ) - start_time
print ( '程序爬了{}页的表格数据,运行了{:.2f}秒' . format ( n, endtime) )
3 小结
最后,需说明不是所有表格都可以用这种方法爬取 。
比如这个网站中的表格,表面是看起来是表格,但在html中不是前面的table
格式,而是list
列表格式。这种表格则不适用read_html
爬取。得用其他的方法,比如selenium
。
引自: [1] 关于python获取网页表格数据(read_html()方法) [2] 利用pandas库中的read_html方法快速抓取网页中常见的表格型数据
你可能感兴趣的:(Python笔记,python)
ESP32 esp-idf开发环境搭建
chem4111
c语言 嵌入式硬件
一、准备工作安装必备工具Python3.8+:建议使用官方推荐的3.8版本,避免高版本兼容性问题(2()])。下载地址:Python3.8.10,安装时勾选AddtoPATH。VisualStudioCode:推荐开发工具,下载地址:VSCode4。配置Python镜像源以管理员身份运行CMD,执行以下命令加速依赖下载:pipconfigsetglobal.index-urlhttps://mir
零基础学习机器学习分类模型
可喜~可乐
机器学习 机器学习 学习 分类 人工智能 数据挖掘
下面将带你通过一个简单的机器学习项目,使用Python实现一个常见的分类问题。我们将使用著名的Iris数据集,来构建一个机器学习模型,进行花卉品种的分类。整个过程会包含:原理介绍:机器学习的基本概念。数据加载和预处理:如何加载数据并进行必要的处理。模型训练和评估:使用经典的分类算法——逻辑回归。代码解释:逐步分析代码实现。拓展内容:如何优化和扩展该项目。1.原理介绍1.1机器学习基本概念机器学习(
【Python】工作流:Jupyter Notebook、Airflow
浪子西科
Python python jupyter 开发语言
工作流:JupyterNotebook、Airflow1.JupyterNotebook1.1安装可以使用pip或者conda进行安装。使用pip安装:pipinstallnotebook使用conda安装:condainstall-cconda-forgenotebook1.2基本概念Notebook文件:以.ipynb为扩展名,它是一个包含代码、文本(支持Markdown格式)、图像和计算结果
【Python】函数详细介绍,附代码详解(参数类型、返回值、作用域、高阶函数、闭包、装饰器、生成器、递归等)
echo 慧
Python学习 python 开发语言 函数 详解 学习
文章目录1.定义2.函数参数类型2.1位置参数2.2默认参数2.3关键字参数2.4可变参数2.4.1*args2.4.2**kwargs2.4.3使用参数的顺序2.5仅限位置参数(Python3.8以上版本)2.6仅限关键字参数3.返回值4.作用域和变量访问5.匿名函数lambda6.高阶函数6.1map()6.2filter()6.3sorted()6.4reduce()7.闭包8.装饰器(De
Jmeter 使用python脚本断言
吕海洋
python jmeter jmeter python Jython
jmeter自带的BeanShell断言支持java,如果想使用Python脚本做断言的话需要安装Jython(java版Python)一、下载jythonDownloads|Jython1、下载JythonStandalone版本的jar包jython-standalone-2.7.3.jar2、将jythonjar包放到jmeterlib/ext下eg.apache-jmeter-5.5/li
SOME/IP-SD -- 协议英文原文讲解1
忆源
SOME/IP-SD tcp/ip 网络 网络协议
前言SOME/IP协议越来越多的用于汽车电子行业中,关于协议详细完全的中文资料却没有,所以我将结合工作经验并对照英文原版协议做一系列的文章。基本分三大块:1.SOME/IP协议讲解2.SOME/IP-SD协议讲解3.python/C++举例调试讲解1IntroductionandoverviewThisprotocolspecificationspecifiestheformat,messages
SOME/IP--协议英文原文讲解1
忆源
SOME/IP AUTOSAR 网络
前言SOME/IP协议越来越多的用于汽车电子行业中,关于协议详细完全的中文资料却没有,所以我将结合工作经验并对照英文原版协议做一系列的文章。基本分三大块:1.SOME/IP协议讲解2.SOME/IP-SD协议讲解3.python/C++举例调试讲解一、SOME/IP由来及协议下载1.历史SOME/IP(Scalableservice-OrientedMiddlewarEoverIP)是由宝马的La
深入解析 Python 的 __str__() 方法重写
web安全工具库
python microsoft 开发语言
各类资料学习下载合集https://pan.quark.cn/s/8c91ccb5a474在Python中,__str__()是一个特殊的方法,用于定义对象的“非正式”字符串表示。重写__str__()方法可以让我们定制类的实例在打印或转换成字符串时的表现。本文将详细讲解__str__()方法的作用、如何重写它,以及具体的代码示例和运行结果。一、什么是__str__()方法__str__()方法是
【python随手记】——读取文本文件内容转换为json格式
番茄番茄君
python json windows
文章目录前言一、TXT文件转换为JSON数组1.txt文件内容2.python代码3.输出结果二、TXT文件转换为JSON对象1.txt文件2.python代码3.输出结果前言场景:用于读取包含空格分隔数据的TXT文件,并将其转换为结构化JSON文件一、TXT文件转换为JSON数组1.txt文件内容地点A116.40528539.90498943.5地标B121.47370131.2304164.
JMeter中使用Python
测试界的飘柔
程序员 软件测试 职场经验 jmeter python 开发语言 软件测试 功能测试 职场经验 自动化测试
要在JMeter中使用Python,需要使用JSR223Sampler元素来执行Python脚本。使用JSR223Sampler执行Python脚本时,需要确保已在JMeter中配置了Python解释器,并设置了正确的环境路径。1、确保JMeter已安装Python解释器,并将解释器的路径添加到计算机的环境变量中。2、在JMeter的lib目录中,创建一个新目录,用于存放Python解释器所需的库
JMeter 如何并发执行 Python 脚本
朱公子的Note
python JMeter执行Python
你是否遇到过这样的场景:需要用Python实现复杂的逻辑处理,同时又想利用JMeter的强大并发能力来模拟大规模用户行为?这篇文章带你快速掌握如何让JMeter并发执行Python脚本,完美结合两者的优势!JMeter如何配置来调用Python脚本?如何实现高效的并发执行?在实践中有哪些需要注意的坑?随着性能测试需求的增加,JMeter的应用场景越来越广泛,而Python的灵活性与强大的第三方库支
【数据挖掘在量化交易中的应用:特征发现与特征提取】
调皮的芋头
数据挖掘 人工智能 神经网络
好的,我将撰写一篇关于金融领域数据挖掘的技术博客,重点阐述特征发现和特征提取,特别是在量化交易中的应用。我会提供具体的实操步骤,并结合Python和TensorFlow进行代码示例。完成后,我会通知您进行查看。数据挖掘在量化交易中的应用:特征发现与特征提取1.概述在金融领域的量化交易中,数据挖掘扮演着极其重要的角色。量化交易依赖于对海量金融数据的分析,从中寻找规律和模式,以支撑交易决策。数据挖掘技
Python 运算符
2401_87587429
python 开发语言
目录前言1.算数运算符2.赋值运算符3.比较运算符4.逻辑运算符5.其他运算符结语前言在编程的世界里,运算符是构建代码逻辑的基础。Python,作为一种功能强大且灵活的编程语言,提供了一套全面的运算符,使得数据处理和操作变得简单高效。本文将带你深入了解Python中的运算符,包括它们的用途、语法和一些实际的例子。1.算数运算符算数运算符用于执行基本的数学运算。以下是Python支持的算数运算符·+
Selenium入门,最近看到的都师一些小白想学测试,今天就分享入门吧~
程序员-小枫
selenium 自动化测试 Python selenium python 软件测试
Selenium入门(自动右键保存图片到本机上)前言入职测开一段时间,基本就是熟悉需求,熟悉业务,熟悉这熟悉那,再跟着需求做各种各样的测试和联调,趁着业余时间,也是学习了一下Selenium,在之前Selenium是我作为爬虫的工具,不过之后就用来做写一些自动化测试脚本啦~~(这里使用Python中的Selenium库进行Coding~~1、什么是SeleniumSelenium是一个用于Web应
python 爬虫 智联招聘
风华明远
Python 爬虫 python
本方法使用cookie的方法下载智联招聘的职位。主要就是要先登录智联招聘,然后将对应的cookie作为爬虫访问的header。代码如下:importrequestsimportreimportxlwtdefparse_one_page(html):'''解析HTML代码,提取有用信息并返回'''#正则表达式进行解析pattern=re.compile('(.*?).*?''(.*?).*?''\\
python使用osgeo库_MAC下python2.7的GDAL库配置问题
weixin_39974223
python使用osgeo库
通过三天的不懈努力解决了mac下GDAL配置问题,顺利的运行了一个简单的python代码1、使用了GDAL_Complete-2.1.dmg简单安装,失败告终,(应该没有正确配置路径、导致调用不出gdal)2、下载源码gdal在利用Swig在nmake.opt中编译,失败告终。安装Swig三次才成功,感谢博主LIANGJIANGLI(MacSwig3.0.12安装),接着就是解译nmake,我是用
智联招聘python岗位_python智联招聘爬虫
weixin_39750854
智联招聘python岗位
博主写了一个智联招聘的爬虫,只要输入职位关键字,就能快速导出智联招聘上的数据,存在excel表里~importrequests,openpyxl#建立excel表joblist=[]wb=openpyxl.Workbook()sheet=wb.activesheet.title='智联招聘数据'sheet['A1']='职位名称'sheet['B1']='薪资'sheet['C1']='工作经验'
python:使用gdal和numpy进行遥感时间序列最大值合成
_养乐多_
python处理遥感数据 python numpy 开发语言
作者:CSDN@_养乐多_本文将介绍使用python编程语言,进行遥感数据时间序列最大值合成的代码。代码中使用了numpy和gdal,通过numpy广播机制实现时间序列最大值合成,并以NDVI时间序列数据为例。代码方便易运行,逻辑简单,速度快。只需要输入单波段遥感数据,就可输出最大值合成影像。输入输出如下图所示,文章目录一、完整代码一、完整代码importosimportglobimportnum
YOLOv8实例分割训练自己的数据集
NoContours
YOLO python 开发语言
转载https://blog.csdn.net/m0_51530640/article/details/1299752571.利用labelme进行数据标注1.1Labelme安装方法首先安装Anaconda,然后运行下列命令:####################forPython2####################condacreate--name=labelmepython=2.7s
青少年Python趣学编程:用代码开启无限可能【文末好书推荐】
一键难忘
好书推荐 python pygame 开发语言
文章目录青少年Python趣学编程:用代码开启无限可能1.为什么选择Python?2.从小游戏开始:让编程变得有趣3.学习编程的关键步骤4.提供项目和挑战:激发创造力《青少年Python趣学编程(微课视频版)》【好书推荐】购书链接本书特色✨内容亮点配套资源适用人群青少年Python趣学编程:用代码开启无限可能在当今数字化的时代,编程已成为一种基础技能,尤其对于青少年来说,学习编程不仅能帮助他们理解
智联招聘爬虫
m0_74823878
面试 学习路线 阿里巴巴 爬虫
使用Python和Selenium进行招聘信息爬取在当今数字化时代,数据已成为企业决策的重要依据。对于人力资源部门或求职者而言,获取最新的招聘信息至关重要。然而,手动浏览和收集招聘信息不仅耗时费力,而且效率低下。为了解决这个问题,我们可以使用Python和Selenium库来自动化这一过程,实现从招聘网站上批量爬取招聘信息。准备工作在开始之前,你需要确保已经安装了以下库:Python(建议版本3.
Mac M1安装Python---kalrry
kalrry
Python python macos 开发语言
MacM1安装Python---kalrry一、准备二、安装三、配置环境变量1、配置环境2、测试3、pip3与pip建立软链接四、参考备份一、准备Python3.9.1发布后开始支持苹果M1和macOS11BigSur也就是我们要下载3.9.1以后的版本,最好选择最新稳定版python官网下载python阿里网盘下载—sa65二、安装双击正常一路next安装即可三、配置环境变量1、配置环境命令行输
记录一次M1芯片Mac折腾安装Python3的过程
Onemud
macos python linux
记录一次M1芯片Mac折腾安装Python3的过程前言:是要用python搞一个跟url接口交互的脚本,来配合做服务迁移工作,但在开发和测试脚本是让python环境卡住了脖(电脑装了很多个python,并且多版本间管理的比较混乱)所以想先调试好一个版本能用就好;并且脚本用到requests库,需要给python安装一下。总结两件事:装好python3.9,得能用给python3.9装上reques
python正态检验_Python检验数据是否正态分布
weixin_39748858
python正态检验
在对数据进行处理前,有事需要判断数据是否呈正态分布,比如线性回归,比如使用3-sigma判断数据是否异常。常用的正态分布检测方法:Shapiro-WilktestShapiro-Wilktest是一种在频率上统计检验中检验正态性的方法。该检验的零检验是样本$x_1,\cdots,x_n$来自于一个正态分布的母体。这个检验的统计量是:$$W=\frac{(\sum_{i=1}^{n}a_{i}x_{
python爬取pdf_python爬取在线教程转成pdf
weixin_39842237
python爬取pdf
1、网站介绍之前再搜资料的时候经常会跳转到如下图所示的在线教程:01.教程样式包括一些github的项目也纷纷将教程链接指向这个网站。经过一番查找,该网站是一个可以创建、托管和浏览文档的网站,其网址为:https://readthedocs.org。在上面可以找到很多优质的资源。该网站虽然提供了下载功能,但是有些教程并没有提供PDF格式文件的下载,如图:02.下载该教程只提供了HTML格式文件的下
Python常见库的使用
浪子西科
Python python 开发语言
文章目录人工智能与机器学习1.NumPy2.Pandas3.Scikit-learn4.TensorFlow5.PyTorch数据可视化1.Matplotlib2.Seaborn网络请求与爬虫1.Requests2.Scrapy自动化测试1.unittest2.pytest自然语言处理1.NLTK2.SpaCy数据库操作1.SQLite32.SQLAlchemy日期和时间处理1.datetime2
python 绘制正态分布图
点云侠
CloudCompare python 开发语言 算法 3d
目录一、概述二、代码实现三、结果展示一、概述 在Python中,可以使用numpy库中的normal()函数或random.normal()方法生成正态分布的随机数,同时也利用scipy库的norm.pdf()函数来计算正态分布的概率密度函数。二、代码实现importnumpyasnpimportmatplotlib.pyplotaspltfromscipy.statsimportnorm#创建
服务器/mac m1配置python环境
LoveSeven.Lin
macos python 开发语言
目录服务器配置环境一、安装miniconda二、创建环境三、激活环境四、conda安装Macm1配置环境一、安装Miniforge3二、创建环境三、激活环境四、安装tensorflow五、测试运行服务器配置环境一、安装miniconda#step1:获取安装shell脚本文件wgethttps://repo.continuum.io/miniconda/Miniconda3-latest-Linu
Mac M1芯片通过源码安装Python2.7.x
乌萨奇敲代码
macos python
文章目录MacM1芯片通过源码安装Python2.7.x1.下载源码2.安装依赖3.配置环境4.配置编译选项5.编译6.验证安装MacM1芯片通过源码安装Python2.7.x首先,由于AppleM1芯片使用的是ARM架构,已经不支持Python2.7.x了,所以需要利用Rosetta手动编译Python2.7.x,这里以安装Python2.7.17为例。1.下载源码首先,从Python官方网站下
在Mac M1上安装Python 3并设置环境变量
JieLun_C
macos python 开发语言 Python
在MacM1上安装Python3并设置环境变量MacM1是基于AppleSilicon芯片的新一代Mac电脑。如果你是MacM1用户,并且想要安装Python3并设置环境变量,那么你来对地方了。本文将为你提供详细的步骤和相应的源代码。以下是在MacM1上安装Python3并设置环境变量的步骤:步骤1:安装HomebrewHomebrew是一个流行的包管理器,可以帮助我们在Mac上安装各种软件包。打
面向对象面向过程
3213213333332132
java
面向对象:把要完成的一件事,通过对象间的协作实现。
面向过程:把要完成的一件事,通过循序依次调用各个模块实现。
我把大象装进冰箱这件事为例,用面向对象和面向过程实现,都是用java代码完成。
1、面向对象
package bigDemo.ObjectOriented;
/**
* 大象类
*
* @Description
* @author FuJian
Java Hotspot: Remove the Permanent Generation
bookjovi
HotSpot
openjdk上关于hotspot将移除永久带的描述非常详细,http://openjdk.java.net/jeps/122
JEP 122: Remove the Permanent Generation
Author Jon Masamitsu
Organization Oracle
Created 2010/8/15
Updated 2011/
正则表达式向前查找向后查找,环绕或零宽断言
dcj3sjt126com
正则表达式
向前查找和向后查找
1. 向前查找:根据要匹配的字符序列后面存在一个特定的字符序列(肯定式向前查找)或不存在一个特定的序列(否定式向前查找)来决定是否匹配。.NET将向前查找称之为零宽度向前查找断言。
对于向前查找,出现在指定项之后的字符序列不会被正则表达式引擎返回。
2. 向后查找:一个要匹配的字符序列前面有或者没有指定的
BaseDao
171815164
seda
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
public class BaseDao {
public Conn
Ant标签详解--Java命令
g21121
Java命令
这一篇主要介绍与java相关标签的使用 终于开始重头戏了,Java部分是我们关注的重点也是项目中用处最多的部分。
1
[简单]代码片段_电梯数字排列
53873039oycg
代码
今天看电梯数字排列是9 18 26这样呈倒N排列的,写了个类似的打印例子,如下:
import java.util.Arrays;
public class 电梯数字排列_S3_Test {
public static void main(S
Hessian原理
云端月影
hessian原理
Hessian 原理分析
一. 远程通讯协议的基本原理
网络通信需要做的就是将流从一台计算机传输到另外一台计算机,基于传输协议和网络 IO 来实现,其中传输协议比较出名的有 http 、 tcp 、 udp 等等, http 、 tcp 、 udp 都是在基于 Socket 概念上为某类应用场景而扩展出的传输协
区分Activity的四种加载模式----以及Intent的setFlags
aijuans
android
在多Activity开发中,有可能是自己应用之间的Activity跳转,或者夹带其他应用的可复用Activity。可能会希望跳转到原来某个Activity实例,而不是产生大量重复的Activity。
这需要为Activity配置特定的加载模式,而不是使用默认的加载模式。 加载模式分类及在哪里配置
Activity有四种加载模式:
standard
singleTop
hibernate几个核心API及其查询分析
antonyup_2006
html .net Hibernate xml 配置管理
(一) org.hibernate.cfg.Configuration类
读取配置文件并创建唯一的SessionFactory对象.(一般,程序初始化hibernate时创建.)
Configuration co
PL/SQL的流程控制
百合不是茶
oracle PL/SQL编程 循环控制
PL/SQL也是一门高级语言,所以流程控制是必须要有的,oracle数据库的pl/sql比sqlserver数据库要难,很多pl/sql中有的sqlserver里面没有
流程控制;
分支语句 if 条件 then 结果 else 结果 end if ;
条件语句 case when 条件 then 结果;
循环语句 loop
强大的Mockito测试框架
bijian1013
mockito 单元测试
一.自动生成Mock类 在需要Mock的属性上标记@Mock注解,然后@RunWith中配置Mockito的TestRunner或者在setUp()方法中显示调用MockitoAnnotations.initMocks(this);生成Mock类即可。二.自动注入Mock类到被测试类 &nbs
精通Oracle10编程SQL(11)开发子程序
bijian1013
oracle 数据库 plsql
/*
*开发子程序
*/
--子程序目是指被命名的PL/SQL块,这种块可以带有参数,可以在不同应用程序中多次调用
--PL/SQL有两种类型的子程序:过程和函数
--开发过程
--建立过程:不带任何参数
CREATE OR REPLACE PROCEDURE out_time
IS
BEGIN
DBMS_OUTPUT.put_line(systimestamp);
E
【EhCache一】EhCache版Hello World
bit1129
Hello world
本篇是EhCache系列的第一篇,总体介绍使用EhCache缓存进行CRUD的API的基本使用,更细节的内容包括EhCache源代码和设计、实现原理在接下来的文章中进行介绍
环境准备
1.新建Maven项目
2.添加EhCache的Maven依赖
<dependency>
<groupId>ne
学习EJB3基础知识笔记
白糖_
bean Hibernate jboss webservice ejb
最近项目进入系统测试阶段,全赖袁大虾领导有力,保持一周零bug记录,这也让自己腾出不少时间补充知识。花了两天时间把“传智播客EJB3.0”看完了,EJB基本的知识也有些了解,在这记录下EJB的部分知识,以供自己以后复习使用。
EJB是sun的服务器端组件模型,最大的用处是部署分布式应用程序。EJB (Enterprise JavaBean)是J2EE的一部分,定义了一个用于开发基
angular.bootstrap
boyitech
AngularJS AngularJS API angular中文api
angular.bootstrap
描述:
手动初始化angular。
这个函数会自动检测创建的module有没有被加载多次,如果有则会在浏览器的控制台打出警告日志,并且不会再次加载。这样可以避免在程序运行过程中许多奇怪的问题发生。
使用方法: angular .
java-谷歌面试题-给定一个固定长度的数组,将递增整数序列写入这个数组。当写到数组尾部时,返回数组开始重新写,并覆盖先前写过的数
bylijinnan
java
public class SearchInShiftedArray {
/**
* 题目:给定一个固定长度的数组,将递增整数序列写入这个数组。当写到数组尾部时,返回数组开始重新写,并覆盖先前写过的数。
* 请在这个特殊数组中找出给定的整数。
* 解答:
* 其实就是“旋转数组”。旋转数组的最小元素见http://bylijinnan.iteye.com/bl
天使还是魔鬼?都是我们制造
ducklsl
生活 教育 情感
----------------------------剧透请原谅,有兴趣的朋友可以自己看看电影,互相讨论哦!!!
从厦门回来的动车上,无意中瞟到了书中推荐的几部关于儿童的电影。当然,这几部电影可能会另大家失望,并不是类似小鬼当家的电影,而是关于“坏小孩”的电影!
自己挑了两部先看了看,但是发现看完之后,心里久久不能平
[机器智能与生物]研究生物智能的问题
comsci
生物
我想,人的神经网络和苍蝇的神经网络,并没有本质的区别...就是大规模拓扑系统和中小规模拓扑分析的区别....
但是,如果去研究活体人类的神经网络和脑系统,可能会受到一些法律和道德方面的限制,而且研究结果也不一定可靠,那么希望从事生物神经网络研究的朋友,不如把
获取Android Device的信息
dai_lm
android
String phoneInfo = "PRODUCT: " + android.os.Build.PRODUCT;
phoneInfo += ", CPU_ABI: " + android.os.Build.CPU_ABI;
phoneInfo += ", TAGS: " + android.os.Build.TAGS;
ph
最佳字符串匹配算法(Damerau-Levenshtein距离算法)的Java实现
datamachine
java 算法 字符串匹配
原文:http://www.javacodegeeks.com/2013/11/java-implementation-of-optimal-string-alignment.html------------------------------------------------------------------------------------------------------------
小学5年级英语单词背诵第一课
dcj3sjt126com
english word
long 长的
show 给...看,出示
mouth 口,嘴
write 写
use 用,使用
take 拿,带来
hand 手
clever 聪明的
often 经常
wash 洗
slow 慢的
house 房子
water 水
clean 清洁的
supper 晚餐
out 在外
face 脸,
macvim的使用实战
dcj3sjt126com
mac vim
macvim用的是mac里面的vim, 只不过是一个GUI的APP, 相当于一个壳
1. 下载macvim
https://code.google.com/p/macvim/
2. 了解macvim
:h vim的使用帮助信息
:h macvim
java二分法查找
蕃薯耀
java二分法查找 二分法 java二分法
java二分法查找
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
蕃薯耀 2015年6月23日 11:40:03 星期二
http:/
Spring Cache注解+Memcached
hanqunfeng
spring memcached
Spring3.1 Cache注解
依赖jar包:
<!-- simple-spring-memcached -->
<dependency>
<groupId>com.google.code.simple-spring-memcached</groupId>
<artifactId>simple-s
apache commons io包快速入门
jackyrong
apache commons
原文参考
http://www.javacodegeeks.com/2014/10/apache-commons-io-tutorial.html
Apache Commons IO 包绝对是好东西,地址在http://commons.apache.org/proper/commons-io/,下面用例子分别介绍:
1) 工具类
2
如何学习编程
lampcy
java 编程 C++ c
首先,我想说一下学习思想.学编程其实跟网络游戏有着类似的效果.开始的时候,你会对那些代码,函数等产生很大的兴趣,尤其是刚接触编程的人,刚学习第一种语言的人.可是,当你一步步深入的时候,你会发现你没有了以前那种斗志.就好象你在玩韩国泡菜网游似的,玩到一定程度,每天就是练级练级,完全是一个想冲到高级别的意志力在支持着你.而学编程就更难了,学了两个月后,总是觉得你好象全都学会了,却又什么都做不了,又没有
架构师之spring-----spring3.0新特性的bean加载控制@DependsOn和@Lazy
nannan408
Spring3
1.前言。
如题。
2.描述。
@DependsOn用于强制初始化其他Bean。可以修饰Bean类或方法,使用该Annotation时可以指定一个字符串数组作为参数,每个数组元素对应于一个强制初始化的Bean。
@DependsOn({"steelAxe","abc"})
@Comp
Spring4+quartz2的配置和代码方式调度
Everyday都不同
代码 配置 spring4 quartz2.x 定时任务
前言:这些天简直被quartz虐哭。。因为quartz 2.x版本相比quartz1.x版本的API改动太多,所以,只好自己去查阅底层API……
quartz定时任务必须搞清楚几个概念:
JobDetail——处理类
Trigger——触发器,指定触发时间,必须要有JobDetail属性,即触发对象
Scheduler——调度器,组织处理类和触发器,配置方式一般只需指定触发
Hibernate入门
tntxia
Hibernate
前言
使用面向对象的语言和关系型的数据库,开发起来很繁琐,费时。由于现在流行的数据库都不面向对象。Hibernate 是一个Java的ORM(Object/Relational Mapping)解决方案。
Hibernte不仅关心把Java对象对应到数据库的表中,而且提供了请求和检索的方法。简化了手工进行JDBC操作的流程。
如
Math类
xiaoxing598
Math
一、Java中的数字(Math)类是final类,不可继承。
1、常数 PI:double圆周率 E:double自然对数
2、截取(注意方法的返回类型) double ceil(double d) 返回不小于d的最小整数 double floor(double d) 返回不大于d的整最大数 int round(float f) 返回四舍五入后的整数 long round