jasperReport+iReport的使用

阅读更多

转载自http://lanyan-lan.iteye.com/blog/424903

(1) 
JasperReports是一个开源的java报表制作引擎 
iReport是JasperReports的一个GUI工具,用来生成JasperReports的jrxml文件。 
JasperReports的报表是用XML文件来定义的,约定用jrxml作后缀名。一个典型的jrxml文件包含以下元素: 
    * - 根元素 
    * - 报表的标题,一篇报表里只在开头打印一次<span class="Apple-converted-space"> </span></span><br style=""><span style="">    * <pageHeader> - 页眉,报表每页开头打印一次<span class="Apple-converted-space"> </span></span><br style=""><span style="">    * <detail> - 报表正文<span class="Apple-converted-space"> </span></span><br style=""><span style="">    * <pageFooter> - 页脚,报表每页末尾打印一次<span class="Apple-converted-space"> </span></span><br style=""><span style="">    * <band> - 定义报表部件,以上所有元素都包含一个band元素作为他们唯一的子元素<span class="Apple-converted-space"> </span></span><br style=""><span style="">  ·Summary:可能需要对几页(你的报表可能有几个页组成)的统计值。比如50个销售记录共占用了3页,那么放置这些统计记录的统计值最好的地方就是summary。<span class="Apple-converted-space"> </span></span><br style=""><span style="">  ·groupHeader:每个表的内容可能需要根据某个属性进行划分显示内容和计算内容,比如希望以月份为单位每组分开显示销售记录,那么就可以定义一个组(组的定义参考后文),groupHeader就是放置组说明或是组标志最好的地方。<span class="Apple-converted-space"> </span></span><br style=""><span style="">  ·Groupfooter:放置组的统计或是说明<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(2)<span class="Apple-converted-space"> </span></span><br style=""><span style="">各元素分析:<span class="Apple-converted-space"> </span></span><br style=""><span style="">static text:静态文本,只是用来在报表中显示;<span class="Apple-converted-space"> </span></span><br style=""><span style="">$P--->表示是参数;<span class="Apple-converted-space"> </span></span><br style=""><span style="">如:"20"+$P{statement_current_date}<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">$F--->表示是textfield变量.<span class="Apple-converted-space"> </span></span><br style=""><span style="">如:$F{account_code}<span class="Apple-converted-space"> </span></span><br style=""><span style="">此变量是在<field name>中定义的.其值是在<queryString>中,通过select数据库后,得到的.<span class="Apple-converted-space"> </span></span><br style=""><span style="">select的列名 = field name<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">$V--->表示一个变量<span class="Apple-converted-space"> </span></span><br style=""><span style="">如:$V{balance}<span class="Apple-converted-space"> </span></span><br style=""><span style="">变量的默认值是在报表中设置的.一般设置为0.其真正的值是通过 $P或$F来获得的.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(3)<span class="Apple-converted-space"> </span></span><br style=""><span style="">A,报表中的QueryString语句,可以通过界面上的DataBase中的Report SQL Query来进行添加-->会自动生成相应的TextField.若不行,则可自动手动添加.<span class="Apple-converted-space"> </span></span><br style=""><span style="">B,如果要直接修改代码,可以选择界面上的'编辑'-->'直接编辑XML Source'-->先进行保存-->就会出现代码界面.<span class="Apple-converted-space"> </span></span><br style=""><span style="">C,如果要修改JASPER REPORT的属性,可以选择界面上的'预览'-->'报表属性'<span class="Apple-converted-space"> </span></span><br style=""><span style="">E,添加group,可以通过点击界面上的相应'group'按钮来添加.<span class="Apple-converted-space"> </span></span><br style=""><span style="">F,隐藏不要的区域,要设bank=0,而不能删除为空.删除为空,则为默认值<span class="Apple-converted-space"> </span></span><br style=""><span style="">G,IReport中的左栏中的各元素的后面的[X,Y]内的数据,是指此元素偏离'左上角'的X,Y距离.<span class="Apple-converted-space"> </span></span><br style=""><span style="">H,设置子报表时,要将子报表的属性中的"上边界,下边界,左边界,右边界"全部设置为0,否则会出现子报表传回来的数据,在主报表中没法对齐的现象.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(4)<span class="Apple-converted-space"> </span></span><br style=""><span style="">当没有数据(是指QueryString语句SELECT出来的数据为NULL)时,设置怎样显示:<span class="Apple-converted-space"> </span></span><br style=""><span style="">相关代码:<span class="Apple-converted-space"> </span></span><br style=""><span style="">whenNoDataType="NoPages / BlankPage / AllSectionsNoDetail"<span class="Apple-converted-space"> </span></span><br style=""><span style="">NoPages:当没数据时,会弹出一个对话框提示你没数据,然后显示一个没激活的框.<span class="Apple-converted-space"> </span></span><br style=""><span style="">BlankPage :不会提示,只是显示一个白纸.<span class="Apple-converted-space"> </span></span><br style=""><span style="">AllSectionsNoDetail:不会提示,但那些静态的文本,以及从上一层或JAVA文件中传来显示的参数,都可以显示.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(5)<span class="Apple-converted-space"> </span></span><br style=""><span style="">内置的报表变量:<span class="Apple-converted-space"> </span></span><br style=""><span style="">$V{PAGE_NUMBER}:(常用)<span class="Apple-converted-space"> </span></span><br style=""><span style="">这个变量保存当前的页号,在报表装填结束的时候,这个变量就保存着最终文档的总页数。所以要在JasperReport的文本字段中显示页号和总页数你都可以用它。<span class="Apple-converted-space"> </span></span><br style=""><span style="">A,<span class="Apple-converted-space"> </span></span><br style=""><span style="">只需要添加一个系统的变量:$V{PAGE_NUMBER};<span class="Apple-converted-space"> </span></span><br style=""><span style="">对于$V{PAGE_NUMBER}:当evaluationTime="Now"时,即是计算当页所在哪一页.   (now:即时执行此表达式.)<span class="Apple-converted-space"> </span></span><br style=""><span style="">                    当evaluationTime="Report"时,即是计算当页所在哪一页.(Report:整个报表执行完后才执行此表达式)<span class="Apple-converted-space"> </span></span><br style=""><span style="">B,<span class="Apple-converted-space"> </span></span><br style=""><span style="">并将其转换为String的类型.<span class="Apple-converted-space"> </span></span><br style=""><span style="">C,总体代码:<span class="Apple-converted-space"> </span></span><br style=""><span style=""><textField evaluationTime="Now"><span class="Apple-converted-space"> </span></span><br style=""><span style="">  <textFieldExpression class="java.lang.String"><span class="Apple-converted-space"> </span></span><br style=""><span style="">"Page " + String.valueOf($V{PAGE_NUMBER}) + "   Of"<span class="Apple-converted-space"> </span></span><br style=""><span style="">  </textFieldExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""></textField><span class="Apple-converted-space"> </span></span><br style=""><span style=""><textField evaluationTime="Report"><span class="Apple-converted-space"> </span></span><br style=""><span style="">  <textFieldExpression class="java.lang.String"><span class="Apple-converted-space"> </span></span><br style=""><span style="">String.valueOf($V{PAGE_NUMBER})<span class="Apple-converted-space"> </span></span><br style=""><span style="">  </textFieldExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""></textField><span class="Apple-converted-space"> </span></span><br style=""><span style="">$V{REPORT_COUNT}:<span class="Apple-converted-space"> </span></span><br style=""><span style="">当evaluationTime=Report时,将记录报表的总记录数.<span class="Apple-converted-space"> </span></span><br style=""><span style="">当evaluationTime=Column时,将记录报表从开始到当前页的总记录数.<span class="Apple-converted-space"> </span></span><br style=""><span style="">Variable COLUMN_NUMBER<span class="Apple-converted-space"> </span></span><br style=""><span style="">这个变量将记录当前的列号。<span class="Apple-converted-space"> </span></span><br style=""><span style="">Variable PAGE_COUNT<span class="Apple-converted-space"> </span></span><br style=""><span style="">这个变量纪录当前页中处理的record的数目。<span class="Apple-converted-space"> </span></span><br style=""><span style="">Variable COLUMN_COUNT<span class="Apple-converted-space"> </span></span><br style=""><span style="">这个变量纪录生成当前列时所处理的record的数目。<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(6)<span class="Apple-converted-space"> </span></span><br style=""><span style="">field的动态显示+动态显示不同的格式:<span class="Apple-converted-space"> </span></span><br style=""><span style="">有些报表可能需要对同种类型的数据根据重要性不同而显示不同的风格。例如,要在订单列表中加亮显示金额超过100$的订单.<span class="Apple-converted-space"> </span></span><br style=""><span style="">而文本域的现实格式不能动态改变,我们如何实现这种功能呢?<span class="Apple-converted-space"> </span></span><br style=""><span style="">解决办法是:<span class="Apple-converted-space"> </span></span><br style=""><span style="">在同样的位置放两个文本域来显示相同的内容,但是设置不同的显示格式,一个正常显示,一个加粗并加亮显示红色,同时还要为他们设定<printWhenExpression>元素,让他们可以根据条件表达式来切换。这里的表达式就是$F{value} < 100(正常显示的文本域)和$F{value} >= 100(加亮显示的文本域)。<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(7)<span class="Apple-converted-space"> </span></span><br style=""><span style="">创建子报表<span class="Apple-converted-space"> </span></span><br style=""><span style="">1)<span class="Apple-converted-space"> </span></span><br style=""><span style="">在代码中,将子报表以参数形式加载:<span class="Apple-converted-space"> </span></span><br style=""><span style="">JasperReport sixUnitPrice = (JasperReport)JRLoader.loadObject("jasper/TrendAve_ItemIntel_6MonthUnitPrice.jasper");<span class="Apple-converted-space"> </span></span><br style=""><span style="">parameters.put("sixUnitPrice", sixUnitPrice);<span class="Apple-converted-space"> </span></span><br style=""><span style="">2)<span class="Apple-converted-space"> </span></span><br style=""><span style="">在主报表中,创建上面的相应参数sixUnitPrice. 其类型为:net.sf.jasperreports.engine.JasperReport<span class="Apple-converted-space"> </span></span><br style=""><span style="">3)<span class="Apple-converted-space"> </span></span><br style=""><span style="">在iReprot中添加,划拉出一块子报表.<span class="Apple-converted-space"> </span></span><br style=""><span style="">在subReport项中,选中:' use connection expression '<span class="Apple-converted-space"> </span></span><br style=""><span style="">在subReport other项中:<span class="Apple-converted-space"> </span></span><br style=""><span style="">设置image expression class=net.sf.jasperreports.engine.JasperReport<span class="Apple-converted-space"> </span></span><br style=""><span style="">设置subreport expression中填写代码中的相应参数:$P{sixUnitPrice}<span class="Apple-converted-space"> </span></span><br style=""><span style="">4)<span class="Apple-converted-space"> </span></span><br style=""><span style="">设置要传到子报表的参数,并在主报表中创建相应的参数.<span class="Apple-converted-space"> </span></span><br style=""><span style="">5)<span class="Apple-converted-space"> </span></span><br style=""><span style="">新建子报表,创建一参数(与主报表传递的参数一样),来接收从主报表传来的参数.-->即可应用了.<span class="Apple-converted-space"> </span></span><br style=""><span style="">说明:<span class="Apple-converted-space"> </span></span><br style=""><span style="">位于多层之下的子报表,也需要从主报表开始时,就可以加载,传递下去,否则加载不了.因为一开始,都是从JAVA文件中从传过来,然后一层层传下去的.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(8)<span class="Apple-converted-space"> </span></span><br style=""><span style="">hashmap参数在报表间传递值的用法<span class="Apple-converted-space"> </span></span><br style=""><span style="">1)<span class="Apple-converted-space"> </span></span><br style=""><span style="">如何带参数:<span class="Apple-converted-space"> </span></span><br style=""><span style="">在某层子报表中创建一个新的子报表,此新子报表,必须从:报表java类中定义-->主报表-->各上级父报表中对此新子报表进行定义(定义此参数+各父报表添加此新报表参数,以便其子报表可以获得)-->目的子报表<span class="Apple-converted-space"> </span></span><br style=""><span style="">2)hashmap参数在报表间传递值的用法<span class="Apple-converted-space"> </span></span><br style=""><span style="">如上的专题记录,$P{group_total_hash}此参数是一个hashmap,从其定义是在子报表中的,最终用:是在主报表中,作为统计数据.<span class="Apple-converted-space"> </span></span><br style=""><span style="">怎样用:<span class="Apple-converted-space"> </span></span><br style=""><span style="">1.<span class="Apple-converted-space"> </span></span><br style=""><span style="">先在主报表,以及子报表中都要定义hashmap,并在子报表的各上层报表进行赋值,使参数可以主报表与子报表中间进行传递:<span class="Apple-converted-space"> </span></span><br style=""><span style=""><parameter name="group_total_hash" isForPrompting="false" class="java.util.HashMap"><span class="Apple-converted-space"> </span></span><br style=""><span style=""><defaultValueExpression ><![CDATA[new java.util.HashMap()]></defaultValueExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""></parameter><span class="Apple-converted-space"> </span></span><br style=""><span style="">2.<span class="Apple-converted-space"> </span></span><br style=""><span style="">在子报表中,在区间的显示属性中添加:<span class="Apple-converted-space"> </span></span><br style=""><span style="">$P{group_total_hash}.put();如下:<span class="Apple-converted-space"> </span></span><br style=""><span style="">$P{trayout_hash}.put("trayout",$F{totalqty}) == null?<span class="Apple-converted-space"> </span></span><br style=""><span style="">Boolean.TRUE:Boolean.TRUE<span class="Apple-converted-space"> </span></span><br style=""><span style="">3.<span class="Apple-converted-space"> </span></span><br style=""><span style="">/*<span class="Apple-converted-space"> </span></span><br style=""><span style="">在主报表中:<span class="Apple-converted-space"> </span></span><br style=""><span style="">子报表的返回值有一个问题:它们是在当前区域的所有元素都被处理之后才返回的。<span class="Apple-converted-space"> </span></span><br style=""><span style="">所以,为了能在主报表中的子报表所在的同一区域显示返回值,我们必须延迟文本域表达式的处理时机。这是通过加入一个无效的分组让表达式在分组结束时处理来实现的,而这个无效分组的效果就是数据源中的每条记录就是一组,而且它自己没有组头和组尾区域。<span class="Apple-converted-space"> </span></span><br style=""><span style="">*/<span class="Apple-converted-space"> </span></span><br style=""><span style="">在主报表中:<span class="Apple-converted-space"> </span></span><br style=""><span style="">添加一Field,设置数据类型为Double,且Evaluation time=Column(否则数据出不来)<span class="Apple-converted-space"> </span></span><br style=""><span style="">$P{group_total_hash}.get();如下:<span class="Apple-converted-space"> </span></span><br style=""><span style="">new Double<span class="Apple-converted-space"> </span></span><br style=""><span style="">(<span class="Apple-converted-space"> </span></span><br style=""><span style="">((Double)$P{trayout_hash}.get("trayout")).doubleValue()<span class="Apple-converted-space"> </span></span><br style=""><span style="">  -<span class="Apple-converted-space"> </span></span><br style=""><span style="">((Double)$P{trayin_hash}.get("trayin")).doubleValue()<span class="Apple-converted-space"> </span></span><br style=""><span style="">)<span class="Apple-converted-space"> </span></span><br style=""><span style="">4.<span class="Apple-converted-space"> </span></span><br style=""><span style="">具体可以参考ACCOUNT中的PL报表,或SCM中的item intelligence报表中的设置及用法:<span class="Apple-converted-space"> </span></span><br style=""><span style="">主报表:<span class="Apple-converted-space"> </span></span><br style=""><span style="">ProfitLoss_basic.jrxml<span class="Apple-converted-space"> </span></span><br style=""><span style="">用于计算各部分total的子报表:<span class="Apple-converted-space"> </span></span><br style=""><span style="">ProfitLoss_basic_subReport_profit_loss_total_year_list.jrxml<span class="Apple-converted-space"> </span></span><br style=""><span style="">或<span class="Apple-converted-space"> </span></span><br style=""><span style="">TrendAve_ItemIntelReport.jrxml<span class="Apple-converted-space"> </span></span><br style=""><span style="">TrendAve_ItemIntel_trayout.jrxml.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(9)<span class="Apple-converted-space"> </span></span><br style=""><span style="">Group的用法:<span class="Apple-converted-space"> </span></span><br style=""><span style="">用法一:(分类显示及计算)<span class="Apple-converted-space"> </span></span><br style=""><span style="">假设有两表:<span class="Apple-converted-space"> </span></span><br style=""><span style="">mysql> select * from A;<span class="Apple-converted-space"> </span></span><br style=""><span style="">+------+------+<span class="Apple-converted-space"> </span></span><br style=""><span style="">| id   | name |<span class="Apple-converted-space"> </span></span><br style=""><span style="">+------+------+<span class="Apple-converted-space"> </span></span><br style=""><span style="">|    1 | hk   |<span class="Apple-converted-space"> </span></span><br style=""><span style="">|    2 | hk   |<span class="Apple-converted-space"> </span></span><br style=""><span style="">+------+------+<span class="Apple-converted-space"> </span></span><br style=""><span style="">mysql> select * from B;<span class="Apple-converted-space"> </span></span><br style=""><span style="">+------+------+------+-------+<span class="Apple-converted-space"> </span></span><br style=""><span style="">| id   | Aid  | name | value |<span class="Apple-converted-space"> </span></span><br style=""><span style="">+------+------+------+-------+<span class="Apple-converted-space"> </span></span><br style=""><span style="">|    1 |    1 | sz   |     1 |<span class="Apple-converted-space"> </span></span><br style=""><span style="">|    1 |    1 | cz   |     1 |<span class="Apple-converted-space"> </span></span><br style=""><span style="">|    2 |    2 | zh   |     1 |<span class="Apple-converted-space"> </span></span><br style=""><span style="">|    2 |    2 | gz   |     1 |<span class="Apple-converted-space"> </span></span><br style=""><span style="">+------+------+------+-------+<span class="Apple-converted-space"> </span></span><br style=""><span style="">报表要分两层,第一层循环查询A表,第二层(即子报表)循环查询B表在属于A表的记录.<span class="Apple-converted-space"> </span></span><br style=""><span style="">若不用group,则会出现(-->后面是各组件中iReport中的位置):<span class="Apple-converted-space"> </span></span><br style=""><span style="">ID    Name  value  -->放于报表中的pageHeader<span class="Apple-converted-space"> </span></span><br style=""><span style="">1     hk     1     -->放于第一层报表中的detail -->循环每一条记录且显示<span class="Apple-converted-space"> </span></span><br style=""><span style="">  1   sz     1     -->放于第二层报表中的detail<span class="Apple-converted-space"> </span></span><br style=""><span style="">  2   cz     1<span class="Apple-converted-space"> </span></span><br style=""><span style="">2     hk     1     //name与上相同<span class="Apple-converted-space"> </span></span><br style=""><span style="">  1   zh     1<span class="Apple-converted-space"> </span></span><br style=""><span style="">  2   gz     1<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">若采用group按照name进行分组,则jasper会把name相同的放入一组,只显示一次.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">采用name分组后的效果:<span class="Apple-converted-space"> </span></span><br style=""><span style="">ID    Name  value  -->放于报表中的pageHeader<span class="Apple-converted-space"> </span></span><br style=""><span style="">1     hk     1     -->放于第一层报表中groupHeader,将所有相同的name集合在一起,只显示一次<span class="Apple-converted-space"> </span></span><br style=""><span style="">  1   sz     1     -->放于第二层报表中的detail<span class="Apple-converted-space"> </span></span><br style=""><span style="">  2   cz     1<span class="Apple-converted-space"> </span></span><br style=""><span style="">  1   zh     1<span class="Apple-converted-space"> </span></span><br style=""><span style="">  2   gz     1<span class="Apple-converted-space"> </span></span><br style=""><span style="">  sum value: 5     -->放于第一层报表中groupFooter<span class="Apple-converted-space"> </span></span><br style=""><span style="">补充说明:<span class="Apple-converted-space"> </span></span><br style=""><span style="">对于上面的group,须先点击"group"按钮进行定义(如:nameGroup).<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">同时,可以以group的基准进行计算(结合变量variable),放于groupFooter.<span class="Apple-converted-space"> </span></span><br style=""><span style="">(1)<span class="Apple-converted-space"> </span></span><br style=""><span style="">在iRport中,新建变量sumValue,定义如下:<span class="Apple-converted-space"> </span></span><br style=""><span style="">variable type: Double<span class="Apple-converted-space"> </span></span><br style=""><span style="">caculation type: sum<span class="Apple-converted-space"> </span></span><br style=""><span style="">Reset type: Group<span class="Apple-converted-space"> </span></span><br style=""><span style="">Reset Group: 上面自定义的group名(如:nameGroup)<span class="Apple-converted-space"> </span></span><br style=""><span style="">variable expression:(即进行计算的表达式) $F{value}<span class="Apple-converted-space"> </span></span><br style=""><span style="">(2)<span class="Apple-converted-space"> </span></span><br style=""><span style="">在groupFooter添加一field:<span class="Apple-converted-space"> </span></span><br style=""><span style="">须定义:<span class="Apple-converted-space"> </span></span><br style=""><span style="">Evaluation time : group,而不是now<span class="Apple-converted-space"> </span></span><br style=""><span style="">Evaluation Group: 上面自定义的group名(如:nameGroup)<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">jasper报表,子报表内容显示重叠<span class="Apple-converted-space"> </span></span><br style=""><span style="">在jasper中,若在detail区域中,把两个一模一样的子报表上下放置.则在循环输出时,会出现上下子报表<span class="Apple-converted-space"> </span></span><br style=""><span style="">输出内容相遮掩的结果.<span class="Apple-converted-space"> </span></span><br style=""><span style="">解决方案:用group分离显示.<span class="Apple-converted-space"> </span></span><br style=""><span style="">把两个子报表,分别放于两个不同的group中,分组条件为主报表的每一个ID,这样,主报表循环显示时,就<span class="Apple-converted-space"> </span></span><br style=""><span style="">会将各分组一一显示出来,不会影响其显示.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">用法二:<span class="Apple-converted-space"> </span></span><br style=""><span style="">利用group来进行分组和实现子报表返回值:<span class="Apple-converted-space"> </span></span><br style=""><span style="">第(8)点的返回值,只适合于非循环性的.<span class="Apple-converted-space"> </span></span><br style=""><span style="">若在主报表的detail区域,需要让每条record都将子报表返回值到对应的record中,则要采用这种方法.上面的方法实现不了.<span class="Apple-converted-space"> </span></span><br style=""><span style="">因为子报表的返回值有一个问题:它们是在当前区域的所有元素都被处理之后才返回的。如果你想在子报表所在的主报表区域显示它的返回值,你最终将看到它们返回的太晚了。<span class="Apple-converted-space"> </span></span><br style=""><span style="">具体实现方法:<span class="Apple-converted-space"> </span></span><br style=""><span style="">1)<span class="Apple-converted-space"> </span></span><br style=""><span style="">先在主报表,子报表建立一个同名的hashmap容器,且将主报表的这个参数作为子报表的传递参数,传到<span class="Apple-converted-space"> </span></span><br style=""><span style="">子报表中.<span class="Apple-converted-space"> </span></span><br style=""><span style="">2)<span class="Apple-converted-space"> </span></span><br style=""><span style="">在报表中,对窗口进行加值:<span class="Apple-converted-space"> </span></span><br style=""><span style="">方式一:<span class="Apple-converted-space"> </span></span><br style=""><span style="">在子报表中,在summary区域的属性中添加:<span class="Apple-converted-space"> </span></span><br style=""><span style="">$P{trayout_hash}.put("trayout",$F{totalqty}) == null?Boolean.TRUE:Boolean.TRUE<span class="Apple-converted-space"> </span></span><br style=""><span style="">方式二:<span class="Apple-converted-space"> </span></span><br style=""><span style="">在子报表中,在summary区域中添加一个不可见的直线元素,且在其中设置:<span class="Apple-converted-space"> </span></span><br style=""><span style=""><line><span class="Apple-converted-space"> </span></span><br style=""><span style="">  <reportElement x="0" y="0" width="0" height="0"><span class="Apple-converted-space"> </span></span><br style=""><span style="">    <printWhenExpression><span class="Apple-converted-space"> </span></span><br style=""><span style="">      $P{trayout_hash}.put("trayout",$F{totalqty}) == null?Boolean.FALSE:Boolean.FALSE<span class="Apple-converted-space"> </span></span><br style=""><span style="">    </printWhenExpression><span class="Apple-converted-space"> </span></span><br style=""><span style="">  </reportElement><span class="Apple-converted-space"> </span></span><br style=""><span style=""></line><span class="Apple-converted-space"> </span></span><br style=""><span style="">3)<span class="Apple-converted-space"> </span></span><br style=""><span style="">在主报表中,添加一个分组,以每条记录作为一个分组.操作如下:<span class="Apple-converted-space"> </span></span><br style=""><span style="">A,点击GROUP按钮.<span class="Apple-converted-space"> </span></span><br style=""><span style="">B,填写组名;<span class="Apple-converted-space"> </span></span><br style=""><span style="">C,分组表达式: $F{item_code}.(也可以id作为分组) -->分组的关键所在<span class="Apple-converted-space"> </span></span><br style=""><span style="">D,选择:是否start on a new page -->让最后所得的分组,是否以分页的形式显示.<span class="Apple-converted-space"> </span></span><br style=""><span style="">4)<span class="Apple-converted-space"> </span></span><br style=""><span style="">对于detail区域中,要返回值的field,这样设置:<span class="Apple-converted-space"> </span></span><br style=""><span style=""><textField evaluationTime="Group" evaluationGroup="itemcodeGroup"><span class="Apple-converted-space"> </span></span><br style=""><span style="">  <reportElement x="335" y="50" width="175" height="15"/><span class="Apple-converted-space"> </span></span><br style=""><span style="">  <textFieldExpression ><span class="Apple-converted-space"> </span></span><br style=""><span style="">    $P{trayout_hash}.get("trayout")<span class="Apple-converted-space"> </span></span><br style=""><span style="">  </textFieldExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""></textField><span class="Apple-converted-space"> </span></span><br style=""><span style="">采用Group实现返回值的说明:<span class="Apple-converted-space"> </span></span><br style=""><span style="">子报表的返回值有一个问题:它们是在当前区域的所有元素都被处理之后才返回的。如果你想在子报<span class="Apple-converted-space"> </span></span><br style=""><span style="">表所在的主报表区域显示它的返回值,你最终将看到它们返回的太晚了。<span class="Apple-converted-space"> </span></span><br style=""><span style="">所以,为了能在主报表中的子报表所在的同一区域显示返回值,我们必须延迟文本域表达式的处理时<span class="Apple-converted-space"> </span></span><br style=""><span style="">机。这是通过加入一个无效的分组让表达式在分组结束时处理来实现的,而这个无效分组的效果就是<span class="Apple-converted-space"> </span></span><br style=""><span style="">数据源中的每条记录就是一组,而且它自己没有组头和组尾区域。<span class="Apple-converted-space"> </span></span><br style=""><span style=""><group ><span class="Apple-converted-space"> </span></span><br style=""><span style="">  <groupExpression>$F{item_code}</groupExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""></group><span class="Apple-converted-space"> </span></span><br style=""><br style=""><br style=""><span style="">(10)<span class="Apple-converted-space"> </span></span><br style=""><span style="">若数据类型设置为Double,则须:<span class="Apple-converted-space"> </span></span><br style=""><span style="">$P{trayout_hash}.get("trayout")-->Object类型;<span class="Apple-converted-space"> </span></span><br style=""><span style="">((Double)$P{trayout_hash}.get("trayout"))-->转换成Double类型;<span class="Apple-converted-space"> </span></span><br style=""><span style="">((Double)$P{trayout_hash}.get("trayout")).doubleValue()-->转换成double类型,进行计算;<span class="Apple-converted-space"> </span></span><br style=""><span style="">new Doubel(A-B)--->将最终结果转换成Double,因为上面设置类型类型时,用了Double.<span class="Apple-converted-space"> </span></span><br style=""><span style="">如下:<span class="Apple-converted-space"> </span></span><br style=""><span style="">new Double<span class="Apple-converted-space"> </span></span><br style=""><span style="">(<span class="Apple-converted-space"> </span></span><br style=""><span style="">((Double)$P{trayout_hash}.get("trayout")).doubleValue()<span class="Apple-converted-space"> </span></span><br style=""><span style="">  -<span class="Apple-converted-space"> </span></span><br style=""><span style="">((Double)$P{trayin_hash}.get("trayin")).doubleValue()<span class="Apple-converted-space"> </span></span><br style=""><span style="">)<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(11)<span class="Apple-converted-space"> </span></span><br style=""><span style="">变量还可以声明来完成引擎内建计算的求值,如:count、sum、average、lowest、highest、 variance等等。一个完成Quantity字段sum计算的变量定义如下:<span class="Apple-converted-space"> </span></span><br style=""><span style=""><variable name="QuantitySum"<span class="Apple-converted-space"> </span></span><br style=""><span style="">class="java.lang.Double" calculation="Sum"><span class="Apple-converted-space"> </span></span><br style=""><span style=""><variableExpression>$F{Quantity}</variableExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""></variable><span class="Apple-converted-space"> </span></span><br style=""><span style="">我们还可以通过制定初始化级别来改变计算过程,默认的级别是Report就是变量仅在报表开始处初 始化一次,一直到报表结束完成计算。<span class="Apple-converted-space"> </span></span><br style=""><span style="">我们可以选择更低的级别让变量在每个Page、Column或者Group级别重新初始化。假如我们想计算 计算每页的总数,变量声明如下:<span class="Apple-converted-space"> </span></span><br style=""><span style=""><variable name="QuantitySum" class="java.lang.Double"<span class="Apple-converted-space"> </span></span><br style=""><span style="">resetType="Page" calculation="Sum"><span class="Apple-converted-space"> </span></span><br style=""><span style=""><variableExpression>$F{Quantity}</variableExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""><initialValueExpression>new Double(0) </initialValueExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""></variable><span class="Apple-converted-space"> </span></span><br style=""><span style="">变量将在每一页的开始处被初始化为0。<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(12)<span class="Apple-converted-space"> </span></span><br style=""><span style="">变量的resetType解释:<span class="Apple-converted-space"> </span></span><br style=""><span style="">报表变量的值可以在每一次迭代(iteration)中被改变,但也可以在装填过程中的某一特定的时间(specified moments)通过它的初始的value表达式恢复其初始值。这一行为是由resetType属性控制的,这一属性规定了报表装填过程中当报表变量在何时需要重新进行初始化(或恢复到初始值)。该元素有五种选项值:<span class="Apple-converted-space"> </span></span><br style=""><span style="">4.1<span class="Apple-converted-space"> </span></span><br style=""><span style="">No Reset:变量将不会使用其initial value expression对自身进行初始化,而将仅报表从变量表达式中所求得的值(resetType=”None”)。<span class="Apple-converted-space"> </span></span><br style=""><span style="">4.2<span class="Apple-converted-space"> </span></span><br style=""><span style="">Report Level Reset:变量将在报表填充过程的起始阶段使用其初始化表达式初始化一次(resetType=”Report”)。<span class="Apple-converted-space"> </span></span><br style=""><span style="">缺省的属性为resetType=”Report”<span class="Apple-converted-space"> </span></span><br style=""><span style="">4.3<span class="Apple-converted-space"> </span></span><br style=""><span style="">Page Level Reset:变量将在每一页的起始时被重新初始化(resetType=”Page”)。<span class="Apple-converted-space"> </span></span><br style=""><span style="">4.4<span class="Apple-converted-space"> </span></span><br style=""><span style="">Colunm Level Reset:变量将在每个新列的开始被初始化(resetType=”Column”)<span class="Apple-converted-space"> </span></span><br style=""><span style="">4.5<span class="Apple-converted-space"> </span></span><br style=""><span style="">Group Level Reset:变量将在每次resetGroup属性提供的break的地方被重新初始化(resetType=”Group”)。<span class="Apple-converted-space"> </span></span><br style=""><span style="">Reset Group<span class="Apple-converted-space"> </span></span><br style=""><span style="">如果存在的话,resetGroup属性包含了报表的组的名字并且仅与resetType=”Gropu”的resetType属性相关联。<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(13)<span class="Apple-converted-space"> </span></span><br style=""><span style="">报表的分层显示方法:<span class="Apple-converted-space"> </span></span><br style=""><span style="">外层,在主报表中查询循环显示;<span class="Apple-converted-space"> </span></span><br style=""><span style="">下层,在子报表中查询循环显示.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><br style=""></p> </div> </div> </div> </div> </div> <!--PC和WAP自适应版--> <div id="SOHUCS" sid="1176554590452133888"></div> <script type="text/javascript" src="/views/front/js/chanyan.js"></script> <!-- 文章页-底部 动态广告位 --> <div class="youdao-fixed-ad" id="detail_ad_bottom"></div> </div> <div class="col-md-3"> <div class="row" id="ad"> <!-- 文章页-右侧1 动态广告位 --> <div id="right-1" class="col-lg-12 col-md-12 col-sm-4 col-xs-4 ad"> <div class="youdao-fixed-ad" id="detail_ad_1"> </div> </div> <!-- 文章页-右侧2 动态广告位 --> <div id="right-2" class="col-lg-12 col-md-12 col-sm-4 col-xs-4 ad"> <div class="youdao-fixed-ad" id="detail_ad_2"></div> </div> <!-- 文章页-右侧3 动态广告位 --> <div id="right-3" class="col-lg-12 col-md-12 col-sm-4 col-xs-4 ad"> <div class="youdao-fixed-ad" id="detail_ad_3"></div> </div> </div> </div> </div> </div> </div> <div class="container"> <h4 class="pt20 mb15 mt0 border-top">你可能感兴趣的:(jasperReport+iReport的使用)</h4> <div id="paradigm-article-related"> <div class="recommend-post mb30"> <ul class="widget-links"> <li><a href="/article/1833721850828517376.htm" title="C++——list常见函数的使用和模拟实现(2)" target="_blank">C++——list常见函数的使用和模拟实现(2)</a> <span class="text-muted">Wangx_wang</span> <a class="tag" taget="_blank" href="/search/c%2B%2B/1.htm">c++</a><a class="tag" taget="_blank" href="/search/list/1.htm">list</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a> <div>在list的上一篇博客里实现了list基本的初始化、插入数据、删除数据的基本功能,这些功能的实现方式只是在原先链表的实现里加入了模版而已,但是list作为一个容器,它还有一个基础的东西——迭代器。list的迭代器和之前实现的string和vector很大不同,这里就专门进行list迭代器基本功能的模拟实现。list的迭代器本质上是一个指向list结点的一个指针,但是因为list的结点在内存中的分布</div> </li> <li><a href="/article/1833716429409579008.htm" title="如何用Kotlin实现MVP架构的Android快速开发框架?" target="_blank">如何用Kotlin实现MVP架构的Android快速开发框架?</a> <span class="text-muted">2401_84132496</span> <a class="tag" taget="_blank" href="/search/%E7%A8%8B%E5%BA%8F%E5%91%98/1.htm">程序员</a><a class="tag" taget="_blank" href="/search/android/1.htm">android</a><a class="tag" taget="_blank" href="/search/kotlin/1.htm">kotlin</a><a class="tag" taget="_blank" href="/search/%E6%9E%B6%E6%9E%84/1.htm">架构</a> <div>下拉刷新和上拉加载更多空页面在断网情况下加载缓存网络请求错误并重新加载基于Kotlin的使用说明(Java的使用具体参考java版本的demo)导入依赖在根目录中的build.gradle文件中加入maven{url“https://jitpack.io”}在应用下的build.gradle文件中加入在自定义的Application类中的onCreate方法中初始化CommonLibrary//初</div> </li> <li><a href="/article/1833708366388621312.htm" title="Python-request库的详细解析" target="_blank">Python-request库的详细解析</a> <span class="text-muted">需要重新演唱</span> <a class="tag" taget="_blank" href="/search/Python/1.htm">Python</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a><a class="tag" taget="_blank" href="/search/request/1.htm">request</a><a class="tag" taget="_blank" href="/search/%E5%BA%93/1.htm">库</a><a class="tag" taget="_blank" href="/search/http/1.htm">http</a><a class="tag" taget="_blank" href="/search/session/1.htm">session</a> <div>引言在现代网络应用中,与服务器进行通信是一个非常基础且重要的功能。Python的requests库是一个非常强大且易于使用的HTTP库,它允许我们发送HTTP请求,与Web服务进行交互。本文将详细介绍requests库的使用,包括其基本概念、常用功能以及一些高级用法。安装requests库在使用requests库之前,我们需要先安装它。可以通过pip命令来安装:pipinstallrequests</div> </li> <li><a href="/article/1833700802527588352.htm" title="linux下全盘查找文件,linux下的查找文件命令find" target="_blank">linux下全盘查找文件,linux下的查找文件命令find</a> <span class="text-muted">大表姐绫蛮蛮</span> <a class="tag" taget="_blank" href="/search/linux%E4%B8%8B%E5%85%A8%E7%9B%98%E6%9F%A5%E6%89%BE%E6%96%87%E4%BB%B6/1.htm">linux下全盘查找文件</a> <div>find1.作用find命令的作用是在目录中搜索文件,它的使用权限是所有用户。2.格式find[path][options][expression]path指定目录路径,系统从这里开始沿着目录树向下查找文件。它是一个路径列表,相互用空格分离,如果不写path,那么默认为当前目录。3.主要参数[options]参数:-depth:使用深度级别的查找过程方式,在某层指定目录中优先查找文件内容。-max</div> </li> <li><a href="/article/1833693488689016832.htm" title="vnpy1.0版本学习-回测模块" target="_blank">vnpy1.0版本学习-回测模块</a> <span class="text-muted">ls13552912394</span> <div>1、学习vnpy,从vnpy1.0开始。主要是学习回测模块的使用。ctaAlgo回测模块的使用。git的链接官方:官方地址。其中最主要碰到的坑,各种关联包的使用和开始启动py文件的方法。官方的说明文档写的不太清楚。详细还是要看官方的,我只写写我的感受和操作。2、首先talib包是比较难装的,需要使用conda命令,版本和依赖的包太乱了。使用anacondaprompt命令提示行执行如下:conda</div> </li> <li><a href="/article/1833692983963250688.htm" title="OpenCV结构分析与形状描述符(14)拟合直线函数fitLine()的使用" target="_blank">OpenCV结构分析与形状描述符(14)拟合直线函数fitLine()的使用</a> <span class="text-muted">jndingxin</span> <a class="tag" taget="_blank" href="/search/OpenCV/1.htm">OpenCV</a><a class="tag" taget="_blank" href="/search/opencv/1.htm">opencv</a><a class="tag" taget="_blank" href="/search/%E4%BA%BA%E5%B7%A5%E6%99%BA%E8%83%BD/1.htm">人工智能</a><a class="tag" taget="_blank" href="/search/%E8%AE%A1%E7%AE%97%E6%9C%BA%E8%A7%86%E8%A7%89/1.htm">计算机视觉</a> <div>操作系统:ubuntu22.04OpenCV版本:OpenCV4.9IDE:VisualStudioCode编程语言:C++11算法描述拟合一条直线到2D或3D点集。fitLine函数通过最小化∑iρ(ri)\sum_i\rho(r_i)∑iρ(ri)来拟合一条直线到2D或3D点集,其中rir_iri是第i个点到直线的距离,而ρ(r)\rho(r)ρ(r)是一个距离函数,可以是以下之一:DIST_</div> </li> <li><a href="/article/1833673440142389248.htm" title="hr标签和注释的总结" target="_blank">hr标签和注释的总结</a> <span class="text-muted">Rashore</span> <a class="tag" taget="_blank" href="/search/web%E9%9B%B6%E5%9F%BA%E7%A1%80%E5%AD%A6%E4%B9%A0/1.htm">web零基础学习</a><a class="tag" taget="_blank" href="/search/html/1.htm">html</a><a class="tag" taget="_blank" href="/search/css/1.htm">css</a><a class="tag" taget="_blank" href="/search/html5/1.htm">html5</a> <div>hr标签的定义与使用说明定义以及使用说明标签定义HTML页面中的主题变化(比如话题的转移),并显示为一条水平线。元素被用来分隔HTML页面中的内容(或者定义一个变化)。实例hr标签的使用HTMLHTML是用于描述web页面的一种语言。CSSCSS定义如何显示HTML元素。html中注释的使用定义注释标签用来在源文档中插入注释。注释不会在浏览器中显示。使用范围我们可使用注释对您的代码进行解释,这样做</div> </li> <li><a href="/article/1833663988014084096.htm" title="CodeArts Snap:辅助你编程的神器" target="_blank">CodeArts Snap:辅助你编程的神器</a> <span class="text-muted">109702008</span> <a class="tag" taget="_blank" href="/search/%E4%BA%BA%E5%B7%A5%E6%99%BA%E8%83%BD/1.htm">人工智能</a><a class="tag" taget="_blank" href="/search/%E7%BC%96%E7%A8%8B/1.htm">编程</a><a class="tag" taget="_blank" href="/search/%E5%8D%8E%E4%B8%BAsnap/1.htm">华为snap</a><a class="tag" taget="_blank" href="/search/%E4%BA%BA%E5%B7%A5%E6%99%BA%E8%83%BD/1.htm">人工智能</a> <div>CodeArtsSnap-VisualStudioMarketplace文心一言CodeArtsSnap:辅助你编程的神器一、简介CodeArtsSnap是一款基于华为云研发大模型开发的智能开发助手,旨在覆盖软件开发的全生命周期,为开发者提供端到端的智能支持。自2023年7月7日在华为开发者大会(Cloud)上推出以来,CodeArtsSnap凭借其强大的功能和便捷的使用体验,受到了广大开发者的热</div> </li> <li><a href="/article/1833637260176748544.htm" title="一篇文章让你搞懂Reflect和Reflect metadata(JavaScript)" target="_blank">一篇文章让你搞懂Reflect和Reflect metadata(JavaScript)</a> <span class="text-muted">小小西爪</span> <a class="tag" taget="_blank" href="/search/Typescript/1.htm">Typescript</a><a class="tag" taget="_blank" href="/search/javascript/1.htm">javascript</a><a class="tag" taget="_blank" href="/search/%E5%89%8D%E7%AB%AF/1.htm">前端</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a> <div>一篇文章让你搞懂Reflect和Reflectmetadata(JavaScript)引言Javascript里经常看到Reflect的使用,但一直搞不明白他和Object的区别,加上在工作中也没有经常用到,一直处于懵懵懂懂的状态。所以下定决心,用这篇文章彻彻底底把它搞明白本文主要涵盖以下4个板块:Reflect什么是ReflectAPIs(Reflect与Object的区别)简单的例子:Obje</div> </li> <li><a href="/article/1833604098805559296.htm" title="嵌入式QT开发:构建高效智能的嵌入式系统" target="_blank">嵌入式QT开发:构建高效智能的嵌入式系统</a> <span class="text-muted">嵌入式大圣</span> <a class="tag" taget="_blank" href="/search/qt/1.htm">qt</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a> <div>摘要:本文深入探讨了嵌入式QT相关的各个方面。从QT框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式QT的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式QT的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式QT与硬件设备的交互,包括输入输出设备的驱动与集成。还涉及</div> </li> <li><a href="/article/1833591492124438528.htm" title="idea中 google-java-format 插件的使用" target="_blank">idea中 google-java-format 插件的使用</a> <span class="text-muted">用户昵称23</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/intellij-idea/1.htm">intellij-idea</a><a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/ide/1.htm">ide</a><a class="tag" taget="_blank" href="/search/%E5%85%A8%E6%96%87%E6%A3%80%E7%B4%A2/1.htm">全文检索</a><a class="tag" taget="_blank" href="/search/%E8%BF%90%E7%BB%B4/1.htm">运维</a> <div>google-java-format是一个重新格式化Java源代码以符合GoogleJavaStyle的插件。一个google-java-format可从插件库下载也可以在IDE的File→Settings–>Plugins中下载。单击Marketplace选项卡,搜索google-java-format插件,然后单击Install按钮。默认情况下,该插件将被禁用。要在当前项目中启用它,请转到Fi</div> </li> <li><a href="/article/1833566780849745920.htm" title="Python数据分析之pandas学习!" target="_blank">Python数据分析之pandas学习!</a> <span class="text-muted">Python_trys</span> <a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E5%88%86%E6%9E%90/1.htm">数据分析</a><a class="tag" taget="_blank" href="/search/pandas/1.htm">pandas</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a><a class="tag" taget="_blank" href="/search/%E5%AD%A6%E4%B9%A0/1.htm">学习</a><a class="tag" taget="_blank" href="/search/ide/1.htm">ide</a> <div>Python中的pandas模块进行数据分析。接下来pandas介绍中将学习到如下8块内容:1、数据结构简介:DataFrame和Series2、数据索引index3、利用pandas查询数据4、利用pandas的DataFrames进行统计分析5、利用pandas实现SQL操作6、利用pandas进行缺失值的处理7、利用pandas实现Excel的数据透视表功能8、多层索引的使用在文章开始前打个</div> </li> <li><a href="/article/1833563753753440256.htm" title="python中.txt文件的使用【txt读取和写入】" target="_blank">python中.txt文件的使用【txt读取和写入】</a> <span class="text-muted">大山很山</span> <a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/windows/1.htm">windows</a><a class="tag" taget="_blank" href="/search/%E6%9C%8D%E5%8A%A1%E5%99%A8/1.htm">服务器</a> <div>读取txt的数据和把数据保存到txt中是python处理数据常用的。将学习笔记记录,作备份和参考。十分感谢别人的分享,很详细,学习参考链接如下:pythonPython读写txt文本文件的操作方法全解析教你利用python如何读取txt中的数据一、txt文件读取1python常用的三种读取文件函数read()#一次性读完全部内容readline()#读取第一行内容readlines()#读取文本所</div> </li> <li><a href="/article/1833556443148677120.htm" title="让Python更加充分的使用Sqlite3" target="_blank">让Python更加充分的使用Sqlite3</a> <span class="text-muted">weixin_33726318</span> <a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E5%BA%93/1.htm">数据库</a><a class="tag" taget="_blank" href="/search/%E8%BF%90%E7%BB%B4/1.htm">运维</a> <div>我最近在涉及大量数据处理的项目中频繁使用sqlite3。我最初的尝试根本不涉及任何数据库,所有的数据都将保存在内存中,包括字典查找、迭代和条件等查询。这很好,但可以放入内存的只有那么多,并且将数据从磁盘重新生成或加载到内存是一个繁琐又耗时的过程。我决定试一试sqlite3。因为只需打开与数据库的连接,这样可以增加可处理的数据量,并将应用程序的加载时间减少到零。此外,我可以通过SQL查询替换很多Py</div> </li> <li><a href="/article/1833553289833181184.htm" title="CANopen补充--时间计算出错" target="_blank">CANopen补充--时间计算出错</a> <span class="text-muted">月落三千雪</span> <a class="tag" taget="_blank" href="/search/CANopen%E6%95%99%E7%A8%8B/1.htm">CANopen教程</a><a class="tag" taget="_blank" href="/search/linux/1.htm">linux</a><a class="tag" taget="_blank" href="/search/c%E8%AF%AD%E8%A8%80/1.htm">c语言</a><a class="tag" taget="_blank" href="/search/%E5%8D%95%E7%89%87%E6%9C%BA/1.htm">单片机</a> <div>本专题相关教程:基于STM32F4的CANOpen移植教程基于STM32F4的CANopen快速SDO通信linux下CANopenforpython的使用基于LinuxC的CANopen移植CANopen补充–时间计算出错CANopen补充–主站检测节点是否在线0前言温馨提示,本文为基于LinuxC的CANopen移植后续。如果你在移植完canfestival之后,需要使用与时间相关的功能,如p</div> </li> <li><a href="/article/1833551148410302464.htm" title="Redis缓存机制(详解)" target="_blank">Redis缓存机制(详解)</a> <span class="text-muted">就是有缘人</span> <a class="tag" taget="_blank" href="/search/redis/1.htm">redis</a><a class="tag" taget="_blank" href="/search/%E7%BC%93%E5%AD%98/1.htm">缓存</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E5%BA%93/1.htm">数据库</a> <div>1.Redis是什么?*redis是*一个运行在内存上的key-value存储系统。是NoSQL数据库之一2.缓存穿透,缓存击穿,缓存雪崩/**缓存穿透*/它会先查询Redis,Redis没有会查询数据库,数据库也没有这就是缓存穿透业界主流解决方案:布隆过滤器布隆过滤器的使用步骤布隆过滤器的使用步骤:1.针对现有所有数据,生成布隆过滤器2.在业务逻辑层,判断Redis之前先检查这个id是否在布隆过</div> </li> <li><a href="/article/1833540310286823424.htm" title="轻松搞定Python多版本共存:小白也能轻松上手的配置指南" target="_blank">轻松搞定Python多版本共存:小白也能轻松上手的配置指南</a> <span class="text-muted">CongSec</span> <a class="tag" taget="_blank" href="/search/%E7%94%B5%E8%84%91%E5%90%84%E7%A7%8D%E7%96%91%E9%9A%BE%E6%9D%82%E7%97%87/1.htm">电脑各种疑难杂症</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/%E6%9C%8D%E5%8A%A1%E5%99%A8/1.htm">服务器</a><a class="tag" taget="_blank" href="/search/linux/1.htm">linux</a> <div>轻松搞定Python多版本共存:小白也能轻松上手的配置指南文章目录轻松搞定Python多版本共存:小白也能轻松上手的配置指南1.引言2.为什么需要Python多版本共存?3.准备工作:下载安装不同版本的Python4.配置环境变量:实现多版本Python的关键步骤1:修改Python可执行文件名步骤2:配置系统环境变量PATH步骤3:验证配置是否成功5.PIP命令的使用1.引言Python作为一种</div> </li> <li><a href="/article/1833535015544254464.htm" title="php做的物资管理系统,基于WEB的物资管理信息系统" target="_blank">php做的物资管理系统,基于WEB的物资管理信息系统</a> <span class="text-muted">weixin_39831705</span> <a class="tag" taget="_blank" href="/search/php%E5%81%9A%E7%9A%84%E7%89%A9%E8%B5%84%E7%AE%A1%E7%90%86%E7%B3%BB%E7%BB%9F/1.htm">php做的物资管理系统</a> <div>长期以来,物资管理工作中的信息管理是采用人工的方式,要付出大量人力,填写各种表格、凭证、账册、卡片和文件。由于信息是随着时间不断变化的,各业务部门对信息的使用要求也各不相同,所以要按照不同的分类经常不断地汇总、统计,往往要做许多重复登记和转抄。这种手工操作的管理方式,不仅浪费人力,而且存在许多缺点:1.处理速度慢,影响信息及时性。2.易出现错误,影响信息精确性。3.不便于查询。4.缺乏综合性,不能</div> </li> <li><a href="/article/1833526700273659904.htm" title="独特的艺术天赋,他对色彩和纹理戏剧性的使用" target="_blank">独特的艺术天赋,他对色彩和纹理戏剧性的使用</a> <span class="text-muted">国际艺术大观</span> <div>JoseRoyo何塞·罗约西班牙,(1945-)何塞·罗约(JoseRoyo,1945-),西班牙画家。1945年出生于西班牙的瓦伦西亚,很早就开始展示他的艺术天赋。9岁时,他的父亲,一位著名的医生和狂热的艺术爱好者,雇用了私人教师来指导罗约的绘画和雕塑。当罗约14岁时,他进入瓦伦西亚的圣卡洛斯皇家美术学院。18岁时,罗约在圣卡洛斯学院的艺术研究主席阿尔道夫-费雷尔-安布拉特的指导下继续进行艺术研</div> </li> <li><a href="/article/1833526446820257792.htm" title="微服务架构详解" target="_blank">微服务架构详解</a> <span class="text-muted">一头狒狒</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/%E5%BE%AE%E6%9C%8D%E5%8A%A1/1.htm">微服务</a><a class="tag" taget="_blank" href="/search/%E6%9E%B6%E6%9E%84/1.htm">架构</a><a class="tag" taget="_blank" href="/search/java/1.htm">java</a> <div>一、微服务架构的由来在微服务架构出现之前,最常用的架构就是单体架构,俗称"一个jar(war)包打天下"。在一个jar包工程中,采用MVC架构,分为表现层,业务层,数据访问层,所有的业务模块,都放在这个工程中集成,如下图所示:随着软件行业规模的增长,这种单体架构的弊端也越来越多,包括:耦合性高,某个地方出问题,很可能影响其他业务模块的使用代码管理成本高,项目沉重,并会随着需求的增加越来越重随着访问</div> </li> <li><a href="/article/1833523414837587968.htm" title="【AI大模型应用开发】【LangChain系列】9. 实用技巧:大模型的流式输出在 OpenAI 和 LangChain 中的使用" target="_blank">【AI大模型应用开发】【LangChain系列】9. 实用技巧:大模型的流式输出在 OpenAI 和 LangChain 中的使用</a> <span class="text-muted">同学小张</span> <a class="tag" taget="_blank" href="/search/%E5%A4%A7%E6%A8%A1%E5%9E%8B/1.htm">大模型</a><a class="tag" taget="_blank" href="/search/%E4%BA%BA%E5%B7%A5%E6%99%BA%E8%83%BD/1.htm">人工智能</a><a class="tag" taget="_blank" href="/search/langchain/1.htm">langchain</a><a class="tag" taget="_blank" href="/search/gpt/1.htm">gpt</a><a class="tag" taget="_blank" href="/search/%E7%AC%94%E8%AE%B0/1.htm">笔记</a><a class="tag" taget="_blank" href="/search/%E7%BB%8F%E9%AA%8C%E5%88%86%E4%BA%AB/1.htm">经验分享</a><a class="tag" taget="_blank" href="/search/agi/1.htm">agi</a> <div>大家好,我是同学小张,日常分享AI知识和实战案例欢迎点赞+关注,持续学习,持续干货输出。+v:jasper_8017一起交流,一起进步。微信公众号也可搜【同学小张】本站文章一览:当大模型的返回文字非常多时,返回完整的结果会耗费比较长的时间。如果等待大模型形成完整的答案再展示给用户,明显会给用户不好的体验。所以,现在市面上大多数的AI应用,在给用户结果时,都是以流式输出的方式展示给用户的。所谓的流式</div> </li> <li><a href="/article/1833516655284678656.htm" title="蓝妖:即将入冬月季还要施水溶肥吗?该用什么肥呢?" target="_blank">蓝妖:即将入冬月季还要施水溶肥吗?该用什么肥呢?</a> <span class="text-muted">蓝妖花园</span> <div>最近很多花友在问,快要入冬了,月季有很多嫩枝,还要追肥吗?用什么肥好呢?关于入冬后施肥的问题,这个需要分地区来区别对待。一、南方无休眠区如果是南方地区,月季冬季没有休眠的,一直持续生长,这种情况下,灌木月季,建议还是按照正常的生长周期来施肥。比如在长枝条的阶段就使用生长通用肥,出花苞后,改用磷酸二氢钾肥,促进花苞生长。如果是藤本月季,进入12月份就需要加大磷钾肥的使用量,甚至可以完全停止使用氮肥。</div> </li> <li><a href="/article/1833488878116368384.htm" title="Matlab实现BP-NSGA-II多目标预测优化方法" target="_blank">Matlab实现BP-NSGA-II多目标预测优化方法</a> <span class="text-muted">含老司开挖掘机</span> <div>本文还有配套的精品资源,点击获取简介:本文涉及将遗传算法优化的BP神经网络与NSGA-II相结合,应用于多目标预测问题的解决。主要内容包括BP神经网络的学习原理、适应度函数的设计与应用、NSGA-II在多目标优化中的作用、多目标预测的策略以及Matlab工具在算法实现中的使用。本文旨在通过这些技术,帮助读者构建出能在多个相互冲突的目标间取得平衡的优化解决方案,并提供完整的Matlab代码实现,以供</div> </li> <li><a href="/article/1833488750928293888.htm" title="java class .method_java Class Method类的使用" target="_blank">java class .method_java Class Method类的使用</a> <span class="text-muted">weixin_39620629</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/class/1.htm">class</a><a class="tag" taget="_blank" href="/search/.method/1.htm">.method</a> <div>packagesample;/**Tochangethistemplate,chooseTools|Templates*andopenthetemplateintheeditor.*/importjava.lang.reflect.Constructor;importjava.lang.reflect.InvocationTargetException;importjava.lang.reflec</div> </li> <li><a href="/article/1833487236922961920.htm" title="linux系统下PostgreSQL的使用" target="_blank">linux系统下PostgreSQL的使用</a> <span class="text-muted">敲代码的雪糕</span> <a class="tag" taget="_blank" href="/search/linux/1.htm">linux</a><a class="tag" taget="_blank" href="/search/linux/1.htm">linux</a><a class="tag" taget="_blank" href="/search/postgresql/1.htm">postgresql</a><a class="tag" taget="_blank" href="/search/%E8%BF%90%E7%BB%B4/1.htm">运维</a> <div>文章目录前言一、安装pgsql数据库二、安装c和c++驱动三、使用1、头文件2、源文件3、main文件4、编译前言最近工作中使用到了pgsql,主要是使用其c++驱动完成数据库创建及增删改查等操作…一、安装pgsql数据库使用命令如下:sudoapt-getinstallpostgresql安装完成,使用如下命令,确认数据库版本:psql--version二、安装c和c++驱动使用如下命令安装c驱</div> </li> <li><a href="/article/1833486732943781888.htm" title="「 自动化测试 」面试题.." target="_blank">「 自动化测试 」面试题..</a> <span class="text-muted">测试界筱筱</span> <a class="tag" taget="_blank" href="/search/%E8%BD%AF%E4%BB%B6%E6%B5%8B%E8%AF%95/1.htm">软件测试</a><a class="tag" taget="_blank" href="/search/servlet/1.htm">servlet</a><a class="tag" taget="_blank" href="/search/%E5%8A%9F%E8%83%BD%E6%B5%8B%E8%AF%95/1.htm">功能测试</a><a class="tag" taget="_blank" href="/search/%E8%BD%AF%E4%BB%B6%E6%B5%8B%E8%AF%95/1.htm">软件测试</a><a class="tag" taget="_blank" href="/search/%E8%87%AA%E5%8A%A8%E5%8C%96%E6%B5%8B%E8%AF%95/1.htm">自动化测试</a><a class="tag" taget="_blank" href="/search/%E7%A8%8B%E5%BA%8F%E4%BA%BA%E7%94%9F/1.htm">程序人生</a><a class="tag" taget="_blank" href="/search/%E8%81%8C%E5%9C%BA%E5%92%8C%E5%8F%91%E5%B1%95/1.htm">职场和发展</a> <div>1.你会封装自动化测试框架吗?自动化框架主要的核心框架就是分层+PO模式:分别为:基础封装层BasePage,PO页面对象层,TestCase测试用例层。然后再加上日志处理模块,ini配置文件读取模块,unittest+ddt数据驱动模块,jenkins持续集成模式组成。2.自动化测试的使用场景?需求稳定,不会频繁变更。研发和测试周期长,需要频繁执行回归测试。需要在多种平台上重复运行相同测试的场景</div> </li> <li><a href="/article/1833481817437597696.htm" title="Promise、async/await 的使用" target="_blank">Promise、async/await 的使用</a> <span class="text-muted">渡鸦七</span> <a class="tag" taget="_blank" href="/search/JavaScript/1.htm">JavaScript</a><a class="tag" taget="_blank" href="/search/%E5%89%8D%E7%AB%AF/1.htm">前端</a><a class="tag" taget="_blank" href="/search/javascript/1.htm">javascript</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a> <div>Promise、async/await的使用目录Promiseasync/awaitPromise什么是Promise?Promise是异步编程的一种解决方案,它代表了一个异步操作的最终结果。它是一个对象,用来传递异步操作的消息,而不是直接传递结果。Promise提供统一的API,各种异步操作都可以用同样的方法进行处理,并提供统一的接口。Promise也有三种状态:Pending(等待中):初始状</div> </li> <li><a href="/article/1833477529952940032.htm" title="《Python 面试热门问题五》" target="_blank">《Python 面试热门问题五》</a> <span class="text-muted">陈在天box</span> <a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a> <div>一、引言Python作为一种广泛应用的高级编程语言,在各个领域都有着重要的地位。在面试中,Python相关的问题常常涉及到语言的基础知识、编程技巧、常用库的使用以及实际项目经验等方面。本文将围绕五个热门的Python面试问题进行深入探讨,帮助读者更好地准备Python面试,提升自己的编程能力和竞争力。二、问题一:Python的数据类型有哪些?(一)基本数据类型数字类型整数(int):Python中</div> </li> <li><a href="/article/1833477025625632768.htm" title="SQL的高级查询练习知识点(day24)" target="_blank">SQL的高级查询练习知识点(day24)</a> <span class="text-muted">小星袁</span> <a class="tag" taget="_blank" href="/search/MySQL%E6%95%B0%E6%8D%AE%E5%BA%93%E5%9F%BA%E7%A1%80%E7%9F%A5%E8%AF%86%E5%A4%A7%E5%85%A8/1.htm">MySQL数据库基础知识大全</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E5%BA%93/1.htm">数据库</a><a class="tag" taget="_blank" href="/search/sql/1.htm">sql</a><a class="tag" taget="_blank" href="/search/mysql/1.htm">mysql</a> <div>目录1学习目标2基础查询2.1语法2.2例子3条件查询3.1含义3.2语法3.3条件表达式3.3.1条件运算符3.3.2例子3.4逻辑表达式3.4.1逻辑运算符3.4.2例子3.5模糊查询3.5.1概述3.5.2例子4DISTINCT关键字4.1含义4.2例子5总结一键三连哦!各位袁友......1学习目标重点掌握基础查询语法重点掌握条件查询语法重点掌握distinct关键字的使用2基础查询2.1</div> </li> <li><a href="/article/1833459118694821888.htm" title="使用 Spring Boot + Geodesy 实现地理空间高精度坐标处理及多样化的距离计算功能" target="_blank">使用 Spring Boot + Geodesy 实现地理空间高精度坐标处理及多样化的距离计算功能</a> <span class="text-muted">Mcband</span> <a class="tag" taget="_blank" href="/search/spring/1.htm">spring</a><a class="tag" taget="_blank" href="/search/boot/1.htm">boot</a> <div>前言之前我们计算地理空间点位之间的距离等操作,是使用mysql自带的函数进行处理,这样的话需要每个操作都要单独编写一个sql语句,非常的麻烦并且时间查询较慢,效率比较低,今天我们使用SpringBoot+Geodesy实现地理空间高精度坐标处理及多样化的距离计算功能,更加方便快捷。这是之前使用mysql进行简单空间操作的文章:mysql中point的使用一、Geodesy框架介绍与特性Geodes</div> </li> <li><a href="/article/65.htm" title="Java常用排序算法/程序员必须掌握的8大排序算法" target="_blank">Java常用排序算法/程序员必须掌握的8大排序算法</a> <span class="text-muted">cugfy</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a> <div>分类: 1)插入排序(直接插入排序、希尔排序) 2)交换排序(冒泡排序、快速排序) 3)选择排序(直接选择排序、堆排序) 4)归并排序 5)分配排序(基数排序) 所需辅助空间最多:归并排序 所需辅助空间最少:堆排序 平均速度最快:快速排序 不稳定:快速排序,希尔排序,堆排序。 先来看看8种排序之间的关系:   1.直接插入排序 (1</div> </li> <li><a href="/article/192.htm" title="【Spark102】Spark存储模块BlockManager剖析" target="_blank">【Spark102】Spark存储模块BlockManager剖析</a> <span class="text-muted">bit1129</span> <a class="tag" taget="_blank" href="/search/manager/1.htm">manager</a> <div>Spark围绕着BlockManager构建了存储模块,包括RDD,Shuffle,Broadcast的存储都使用了BlockManager。而BlockManager在实现上是一个针对每个应用的Master/Executor结构,即Driver上BlockManager充当了Master角色,而各个Slave上(具体到应用范围,就是Executor)的BlockManager充当了Slave角色</div> </li> <li><a href="/article/319.htm" title="linux 查看端口被占用情况详解" target="_blank">linux 查看端口被占用情况详解</a> <span class="text-muted">daizj</span> <a class="tag" taget="_blank" href="/search/linux/1.htm">linux</a><a class="tag" taget="_blank" href="/search/%E7%AB%AF%E5%8F%A3%E5%8D%A0%E7%94%A8/1.htm">端口占用</a><a class="tag" taget="_blank" href="/search/netstat/1.htm">netstat</a><a class="tag" taget="_blank" href="/search/lsof/1.htm">lsof</a> <div>经常在启动一个程序会碰到端口被占用,这里讲一下怎么查看端口是否被占用,及哪个程序占用,怎么Kill掉已占用端口的程序   1、lsof -i:port port为端口号   [root@slave /data/spark-1.4.0-bin-cdh4]# lsof -i:8080 COMMAND   PID USER   FD   TY</div> </li> <li><a href="/article/446.htm" title="Hosts文件使用" target="_blank">Hosts文件使用</a> <span class="text-muted">周凡杨</span> <a class="tag" taget="_blank" href="/search/hosts/1.htm">hosts</a><a class="tag" taget="_blank" href="/search/locahost/1.htm">locahost</a> <div>     一切都要从localhost说起,经常在tomcat容器起动后,访问页面时输入http://localhost:8088/index.jsp,大家都知道localhost代表本机地址,如果本机IP是10.10.134.21,那就相当于http://10.10.134.21:8088/index.jsp,有时候也会看到http: 127.0.0.1:</div> </li> <li><a href="/article/573.htm" title="java excel工具" target="_blank">java excel工具</a> <span class="text-muted">g21121</span> <a class="tag" taget="_blank" href="/search/Java+excel/1.htm">Java excel</a> <div>直接上代码,一看就懂,利用的是jxl: import java.io.File; import java.io.IOException; import jxl.Cell; import jxl.Sheet; import jxl.Workbook; import jxl.read.biff.BiffException; import jxl.write.Label; import </div> </li> <li><a href="/article/700.htm" title="web报表工具finereport常用函数的用法总结(数组函数)" target="_blank">web报表工具finereport常用函数的用法总结(数组函数)</a> <span class="text-muted">老A不折腾</span> <a class="tag" taget="_blank" href="/search/finereport/1.htm">finereport</a><a class="tag" taget="_blank" href="/search/web%E6%8A%A5%E8%A1%A8/1.htm">web报表</a><a class="tag" taget="_blank" href="/search/%E5%87%BD%E6%95%B0%E6%80%BB%E7%BB%93/1.htm">函数总结</a> <div>ADD2ARRAY ADDARRAY(array,insertArray, start):在数组第start个位置插入insertArray中的所有元素,再返回该数组。 示例: ADDARRAY([3,4, 1, 5, 7], [23, 43, 22], 3)返回[3, 4, 23, 43, 22, 1, 5, 7]. ADDARRAY([3,4, 1, 5, 7], "测试&q</div> </li> <li><a href="/article/827.htm" title="游戏服务器网络带宽负载计算" target="_blank">游戏服务器网络带宽负载计算</a> <span class="text-muted">墙头上一根草</span> <a class="tag" taget="_blank" href="/search/%E6%9C%8D%E5%8A%A1%E5%99%A8/1.htm">服务器</a> <div>家庭所安装的4M,8M宽带。其中M是指,Mbits/S 其中要提前说明的是: 8bits = 1Byte 即8位等于1字节。我们硬盘大小50G。意思是50*1024M字节,约为 50000多字节。但是网宽是以“位”为单位的,所以,8Mbits就是1M字节。是容积体积的单位。 8Mbits/s后面的S是秒。8Mbits/s意思是 每秒8M位,即每秒1M字节。 我是在计算我们网络流量时想到的</div> </li> <li><a href="/article/954.htm" title="我的spring学习笔记2-IoC(反向控制 依赖注入)" target="_blank">我的spring学习笔记2-IoC(反向控制 依赖注入)</a> <span class="text-muted">aijuans</span> <a class="tag" taget="_blank" href="/search/Spring+3+%E7%B3%BB%E5%88%97/1.htm">Spring 3 系列</a> <div>IoC(反向控制 依赖注入)这是Spring提出来了,这也是Spring一大特色。这里我不用多说,我们看Spring教程就可以了解。当然我们不用Spring也可以用IoC,下面我将介绍不用Spring的IoC。 IoC不是框架,她是java的技术,如今大多数轻量级的容器都会用到IoC技术。这里我就用一个例子来说明: 如:程序中有 Mysql.calss 、Oracle.class 、SqlSe</div> </li> <li><a href="/article/1081.htm" title="高性能mysql 之 选择存储引擎(一)" target="_blank">高性能mysql 之 选择存储引擎(一)</a> <span class="text-muted">annan211</span> <a class="tag" taget="_blank" href="/search/mysql/1.htm">mysql</a><a class="tag" taget="_blank" href="/search/InnoDB/1.htm">InnoDB</a><a class="tag" taget="_blank" href="/search/MySQL%E5%BC%95%E6%93%8E/1.htm">MySQL引擎</a><a class="tag" taget="_blank" href="/search/%E5%AD%98%E5%82%A8%E5%BC%95%E6%93%8E/1.htm">存储引擎</a> <div> 1 没有特殊情况,应尽可能使用InnoDB存储引擎。   原因:InnoDB 和 MYIsAM 是mysql 最常用、使用最普遍的存储引擎。其中InnoDB是最重要、最广泛的存储引擎。她   被设计用来处理大量的短期事务。短期事务大部分情况下是正常提交的,很少有回滚的情况。InnoDB的性能和自动崩溃   恢复特性使得她在非事务型存储的需求中也非常流行,除非有非常</div> </li> <li><a href="/article/1208.htm" title="UDP网络编程" target="_blank">UDP网络编程</a> <span class="text-muted">百合不是茶</span> <a class="tag" taget="_blank" href="/search/UDP%E7%BC%96%E7%A8%8B/1.htm">UDP编程</a><a class="tag" taget="_blank" href="/search/%E5%B1%80%E5%9F%9F%E7%BD%91%E7%BB%84%E6%92%AD/1.htm">局域网组播</a> <div>  UDP是基于无连接的,不可靠的传输   与TCP/IP相反       UDP实现私聊,发送方式客户端,接受方式服务器 package netUDP_sc; import java.net.DatagramPacket; import java.net.DatagramSocket; import java.net.Ine</div> </li> <li><a href="/article/1335.htm" title="JQuery对象的val()方法执行结果分析" target="_blank">JQuery对象的val()方法执行结果分析</a> <span class="text-muted">bijian1013</span> <a class="tag" taget="_blank" href="/search/JavaScript/1.htm">JavaScript</a><a class="tag" taget="_blank" href="/search/js/1.htm">js</a><a class="tag" taget="_blank" href="/search/jquery/1.htm">jquery</a> <div>        JavaScript中,如果id对应的标签不存在(同理JAVA中,如果对象不存在),则调用它的方法会报错或抛异常。在实际开发中,发现JQuery在id对应的标签不存在时,调其val()方法不会报错,结果是undefined。         </div> </li> <li><a href="/article/1462.htm" title="http请求测试实例(采用json-lib解析)" target="_blank">http请求测试实例(采用json-lib解析)</a> <span class="text-muted">bijian1013</span> <a class="tag" taget="_blank" href="/search/json/1.htm">json</a><a class="tag" taget="_blank" href="/search/http/1.htm">http</a> <div>        由于fastjson只支持JDK1.5版本,因些对于JDK1.4的项目,可以采用json-lib来解析JSON数据。如下是http请求的另外一种写法,仅供参考。 package com; import java.util.HashMap; import java.util.Map; import </div> </li> <li><a href="/article/1589.htm" title="【RPC框架Hessian四】Hessian与Spring集成" target="_blank">【RPC框架Hessian四】Hessian与Spring集成</a> <span class="text-muted">bit1129</span> <a class="tag" taget="_blank" href="/search/hessian/1.htm">hessian</a> <div>在【RPC框架Hessian二】Hessian 对象序列化和反序列化一文中介绍了基于Hessian的RPC服务的实现步骤,在那里使用Hessian提供的API完成基于Hessian的RPC服务开发和客户端调用,本文使用Spring对Hessian的集成来实现Hessian的RPC调用。   定义模型、接口和服务器端代码 |---Model    &nb</div> </li> <li><a href="/article/1716.htm" title="【Mahout三】基于Mahout CBayes算法的20newsgroup流程分析" target="_blank">【Mahout三】基于Mahout CBayes算法的20newsgroup流程分析</a> <span class="text-muted">bit1129</span> <a class="tag" taget="_blank" href="/search/Mahout/1.htm">Mahout</a> <div>1.Mahout环境搭建  1.下载Mahout http://mirror.bit.edu.cn/apache/mahout/0.10.0/mahout-distribution-0.10.0.tar.gz    2.解压Mahout  3. 配置环境变量 vim /etc/profile export HADOOP_HOME=/home</div> </li> <li><a href="/article/1843.htm" title="nginx负载tomcat遇非80时的转发问题" target="_blank">nginx负载tomcat遇非80时的转发问题</a> <span class="text-muted">ronin47</span> <div>  nginx负载后端容器是tomcat(其它容器如WAS,JBOSS暂没发现这个问题)非80端口,遇到跳转异常问题。解决的思路是:$host:port        详细如下:    该问题是最先发现的,由于之前对nginx不是特别的熟悉所以该问题是个入门级别的: ? 1 2 3 4 5 </div> </li> <li><a href="/article/1970.htm" title="java-17-在一个字符串中找到第一个只出现一次的字符" target="_blank">java-17-在一个字符串中找到第一个只出现一次的字符</a> <span class="text-muted">bylijinnan</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a> <div> public class FirstShowOnlyOnceElement { /**Q17.在一个字符串中找到第一个只出现一次的字符。如输入abaccdeff,则输出b * 1.int[] count:count[i]表示i对应字符出现的次数 * 2.将26个英文字母映射:a-z <--> 0-25 * 3.假设全部字母都是小写 */ pu</div> </li> <li><a href="/article/2097.htm" title="mongoDB 复制集" target="_blank">mongoDB 复制集</a> <span class="text-muted">开窍的石头</span> <a class="tag" taget="_blank" href="/search/mongodb/1.htm">mongodb</a> <div>mongo的复制集就像mysql的主从数据库,当你往其中的主复制集(primary)写数据的时候,副复制集(secondary)会自动同步主复制集(Primary)的数据,当主复制集挂掉以后其中的一个副复制集会自动成为主复制集。提供服务器的可用性。和防止当机问题             mo</div> </li> <li><a href="/article/2224.htm" title="[宇宙与天文]宇宙时代的经济学" target="_blank">[宇宙与天文]宇宙时代的经济学</a> <span class="text-muted">comsci</span> <a class="tag" taget="_blank" href="/search/%E7%BB%8F%E6%B5%8E/1.htm">经济</a> <div>     宇宙尺度的交通工具一般都体型巨大,造价高昂。。。。。      在宇宙中进行航行,近程采用反作用力类型的发动机,需要消耗少量矿石燃料,中远程航行要采用量子或者聚变反应堆发动机,进行超空间跳跃,要消耗大量高纯度水晶体能源      以目前地球上国家的经济发展水平来讲,</div> </li> <li><a href="/article/2351.htm" title="Git忽略文件" target="_blank">Git忽略文件</a> <span class="text-muted">Cwind</span> <a class="tag" taget="_blank" href="/search/git/1.htm">git</a> <div>     有很多文件不必使用git管理。例如Eclipse或其他IDE生成的项目文件,编译生成的各种目标或临时文件等。使用git status时,会在Untracked files里面看到这些文件列表,在一次需要添加的文件比较多时(使用git add . / git add -u),会把这些所有的未跟踪文件添加进索引。 ==== ==== ==== 一些牢骚</div> </li> <li><a href="/article/2478.htm" title="MySQL连接数据库的必须配置" target="_blank">MySQL连接数据库的必须配置</a> <span class="text-muted">dashuaifu</span> <a class="tag" taget="_blank" href="/search/mysql/1.htm">mysql</a><a class="tag" taget="_blank" href="/search/%E8%BF%9E%E6%8E%A5%E6%95%B0%E6%8D%AE%E5%BA%93%E9%85%8D%E7%BD%AE/1.htm">连接数据库配置</a> <div>MySQL连接数据库的必须配置   1.driverClass:com.mysql.jdbc.Driver   2.jdbcUrl:jdbc:mysql://localhost:3306/dbname   3.user:username   4.password:password   其中1是驱动名;2是url,这里的‘dbna</div> </li> <li><a href="/article/2605.htm" title="一生要养成的60个习惯" target="_blank">一生要养成的60个习惯</a> <span class="text-muted">dcj3sjt126com</span> <a class="tag" taget="_blank" href="/search/%E4%B9%A0%E6%83%AF/1.htm">习惯</a> <div>一生要养成的60个习惯 第1篇 让你更受大家欢迎的习惯 1 守时,不准时赴约,让别人等,会失去很多机会。 如何做到: ①该起床时就起床, ②养成任何事情都提前15分钟的习惯。 ③带本可以随时阅读的书,如果早了就拿出来读读。 ④有条理,生活没条理最容易耽误时间。 ⑤提前计划:将重要和不重要的事情岔开。 ⑥今天就准备好明天要穿的衣服。 ⑦按时睡觉,这会让按时起床更容易。 2 注重</div> </li> <li><a href="/article/2732.htm" title="[介绍]Yii 是什么" target="_blank">[介绍]Yii 是什么</a> <span class="text-muted">dcj3sjt126com</span> <a class="tag" taget="_blank" href="/search/PHP/1.htm">PHP</a><a class="tag" taget="_blank" href="/search/yii2/1.htm">yii2</a> <div>Yii 是一个高性能,基于组件的 PHP 框架,用于快速开发现代 Web 应用程序。名字 Yii (读作 易)在中文里有“极致简单与不断演变”两重含义,也可看作 Yes It Is! 的缩写。 Yii 最适合做什么? Yii 是一个通用的 Web 编程框架,即可以用于开发各种用 PHP 构建的 Web 应用。因为基于组件的框架结构和设计精巧的缓存支持,它特别适合开发大型应</div> </li> <li><a href="/article/2859.htm" title="Linux SSH常用总结" target="_blank">Linux SSH常用总结</a> <span class="text-muted">eksliang</span> <a class="tag" taget="_blank" href="/search/linux+ssh/1.htm">linux ssh</a><a class="tag" taget="_blank" href="/search/SSHD/1.htm">SSHD</a> <div>转载请出自出处:http://eksliang.iteye.com/blog/2186931 一、连接到远程主机   格式: ssh name@remoteserver 例如: ssh ickes@192.168.27.211   二、连接到远程主机指定的端口   格式: ssh name@remoteserver -p 22 例如: ssh i</div> </li> <li><a href="/article/2986.htm" title="快速上传头像到服务端工具类FaceUtil" target="_blank">快速上传头像到服务端工具类FaceUtil</a> <span class="text-muted">gundumw100</span> <a class="tag" taget="_blank" href="/search/android/1.htm">android</a> <div>快速迭代用 import java.io.DataOutputStream; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOExceptio</div> </li> <li><a href="/article/3113.htm" title="jQuery入门之怎么使用" target="_blank">jQuery入门之怎么使用</a> <span class="text-muted">ini</span> <a class="tag" taget="_blank" href="/search/JavaScript/1.htm">JavaScript</a><a class="tag" taget="_blank" href="/search/html/1.htm">html</a><a class="tag" taget="_blank" href="/search/jquery/1.htm">jquery</a><a class="tag" taget="_blank" href="/search/Web/1.htm">Web</a><a class="tag" taget="_blank" href="/search/css/1.htm">css</a> <div>jQuery的强大我何问起(个人主页:hovertree.com)就不用多说了,那么怎么使用jQuery呢?   首先,下载jquery。下载地址:http://hovertree.com/hvtart/bjae/b8627323101a4994.htm,一个是压缩版本,一个是未压缩版本,如果在开发测试阶段,可以使用未压缩版本,实际应用一般使用压缩版本(min)。然后就在页面上引用。</div> </li> <li><a href="/article/3240.htm" title="带filter的hbase查询优化" target="_blank">带filter的hbase查询优化</a> <span class="text-muted">kane_xie</span> <a class="tag" taget="_blank" href="/search/%E6%9F%A5%E8%AF%A2%E4%BC%98%E5%8C%96/1.htm">查询优化</a><a class="tag" taget="_blank" href="/search/hbase/1.htm">hbase</a><a class="tag" taget="_blank" href="/search/RandomRowFilter/1.htm">RandomRowFilter</a> <div> 问题描述 hbase scan数据缓慢,server端出现LeaseException。hbase写入缓慢。   问题原因 直接原因是: hbase client端每次和regionserver交互的时候,都会在服务器端生成一个Lease,Lease的有效期由参数hbase.regionserver.lease.period确定。如果hbase scan需</div> </li> <li><a href="/article/3367.htm" title="java设计模式-单例模式" target="_blank">java设计模式-单例模式</a> <span class="text-muted">men4661273</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/%E5%8D%95%E4%BE%8B/1.htm">单例</a><a class="tag" taget="_blank" href="/search/%E6%9E%9A%E4%B8%BE/1.htm">枚举</a><a class="tag" taget="_blank" href="/search/%E5%8F%8D%E5%B0%84/1.htm">反射</a><a class="tag" taget="_blank" href="/search/IOC/1.htm">IOC</a> <div>         单例模式1,饿汉模式 //饿汉式单例类.在类初始化时,已经自行实例化 public class Singleton1 { //私有的默认构造函数 private Singleton1() {} //已经自行实例化 private static final Singleton1 singl</div> </li> <li><a href="/article/3494.htm" title="mongodb 查询某一天所有信息的3种方法,根据日期查询" target="_blank">mongodb 查询某一天所有信息的3种方法,根据日期查询</a> <span class="text-muted">qiaolevip</span> <a class="tag" taget="_blank" href="/search/%E6%AF%8F%E5%A4%A9%E8%BF%9B%E6%AD%A5%E4%B8%80%E7%82%B9%E7%82%B9/1.htm">每天进步一点点</a><a class="tag" taget="_blank" href="/search/%E5%AD%A6%E4%B9%A0%E6%B0%B8%E6%97%A0%E6%AD%A2%E5%A2%83/1.htm">学习永无止境</a><a class="tag" taget="_blank" href="/search/mongodb/1.htm">mongodb</a><a class="tag" taget="_blank" href="/search/%E7%BA%B5%E8%A7%82%E5%8D%83%E8%B1%A1/1.htm">纵观千象</a> <div>// mongodb的查询真让人难以琢磨,就查询单天信息,都需要花费一番功夫才行。 // 第一种方式: coll.aggregate([ {$project:{sendDate: {$substr: ['$sendTime', 0, 10]}, sendTime: 1, content:1}}, {$match:{sendDate: '2015-</div> </li> <li><a href="/article/3621.htm" title="二维数组转换成JSON" target="_blank">二维数组转换成JSON</a> <span class="text-muted">tangqi609567707</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/%E4%BA%8C%E7%BB%B4%E6%95%B0%E7%BB%84/1.htm">二维数组</a><a class="tag" taget="_blank" href="/search/json/1.htm">json</a> <div>原文出处:http://blog.csdn.net/springsen/article/details/7833596 public class Demo {     public static void main(String[] args) {        String[][] blogL</div> </li> <li><a href="/article/3748.htm" title="erlang supervisor" target="_blank">erlang supervisor</a> <span class="text-muted">wudixiaotie</span> <a class="tag" taget="_blank" href="/search/erlang/1.htm">erlang</a> <div>定义supervisor时,如果是监控celuesimple_one_for_one则删除children的时候就用supervisor:terminate_child (SupModuleName, ChildPid),如果shutdown策略选择的是brutal_kill,那么supervisor会调用exit(ChildPid, kill),这样的话如果Child的behavior是gen_</div> </li> </ul> </div> </div> </div> <div> <div class="container"> <div class="indexes"> <strong>按字母分类:</strong> <a href="/tags/A/1.htm" target="_blank">A</a><a href="/tags/B/1.htm" target="_blank">B</a><a href="/tags/C/1.htm" target="_blank">C</a><a href="/tags/D/1.htm" target="_blank">D</a><a href="/tags/E/1.htm" target="_blank">E</a><a href="/tags/F/1.htm" target="_blank">F</a><a href="/tags/G/1.htm" target="_blank">G</a><a href="/tags/H/1.htm" target="_blank">H</a><a href="/tags/I/1.htm" target="_blank">I</a><a href="/tags/J/1.htm" target="_blank">J</a><a href="/tags/K/1.htm" target="_blank">K</a><a href="/tags/L/1.htm" target="_blank">L</a><a href="/tags/M/1.htm" target="_blank">M</a><a href="/tags/N/1.htm" target="_blank">N</a><a href="/tags/O/1.htm" target="_blank">O</a><a href="/tags/P/1.htm" target="_blank">P</a><a href="/tags/Q/1.htm" target="_blank">Q</a><a href="/tags/R/1.htm" target="_blank">R</a><a href="/tags/S/1.htm" target="_blank">S</a><a href="/tags/T/1.htm" target="_blank">T</a><a href="/tags/U/1.htm" target="_blank">U</a><a href="/tags/V/1.htm" target="_blank">V</a><a href="/tags/W/1.htm" target="_blank">W</a><a href="/tags/X/1.htm" target="_blank">X</a><a href="/tags/Y/1.htm" target="_blank">Y</a><a href="/tags/Z/1.htm" target="_blank">Z</a><a href="/tags/0/1.htm" target="_blank">其他</a> </div> </div> </div> <footer id="footer" class="mb30 mt30"> <div class="container"> <div class="footBglm"> <a target="_blank" href="/">首页</a> - <a target="_blank" href="/custom/about.htm">关于我们</a> - <a target="_blank" href="/search/Java/1.htm">站内搜索</a> - <a target="_blank" href="/sitemap.txt">Sitemap</a> - <a target="_blank" href="/custom/delete.htm">侵权投诉</a> </div> <div class="copyright">版权所有 IT知识库 CopyRight © 2000-2050 E-COM-NET.COM , All Rights Reserved. <!-- <a href="https://beian.miit.gov.cn/" rel="nofollow" target="_blank">京ICP备09083238号</a><br>--> </div> </div> </footer> <!-- 代码高亮 --> <script type="text/javascript" src="/static/syntaxhighlighter/scripts/shCore.js"></script> <script type="text/javascript" src="/static/syntaxhighlighter/scripts/shLegacy.js"></script> <script type="text/javascript" src="/static/syntaxhighlighter/scripts/shAutoloader.js"></script> <link type="text/css" rel="stylesheet" href="/static/syntaxhighlighter/styles/shCoreDefault.css"/> <script type="text/javascript" src="/static/syntaxhighlighter/src/my_start_1.js"></script> </body> </html>