- 使用poi替换XWPFTableCell内容,并设置行间距
RR369_yyh
javaUtiljavapoi
使用poi读取word文档(docx类型),进行数据替换。另外,为了记录poi设置行间距的api,真是找了好几十分钟才找到啊啊啊啊!!!importorg.apache.poi.xwpf.usermodel.*;importorg.springframework.util.StringUtils;importjava.io.File;importjava.io.FileInputStream;im
- 一个Java中有用的StringUtil类
丷丩
通用Springjava工具类
一、Java中StringUtil工具在Java开发中,字符串处理是一项非常常见且必不可少的任务。为了方便进行字符串的操作和处理,通常会使用一些工具类来提供各种功能。本文将提供一个基于String的StringUtil的工具类,它继承自Spring的StringUtils类,并提供了一系列实用的方法来处理字符串。二、Java中字符串处理要求的一般方法在Java中,字符串处理通常包括以下一些常见的操
- isEmpty 和 isBlank 的区别【送源码】
架构文摘JGWZ
学习StringUtils开源
isEmpty系列StringUtils.isEmpty()是否为空.可以看到""空格是会绕过这种空判断,因为是一个空格,并不是严格的空值,会导致isEmpty("")=falseStringUtils.isEmpty(null) = trueStringUtils.isEmpty("") = trueStringUtils.isEmpty(" ") = falseStringUtils.isEm
- java分布式ID生成组件
hong_myth
微服务springcloudJava
1、新建WorkId类packagecom.hua.common.id;importorg.apache.commons.lang3.RandomUtils;importorg.apache.commons.lang3.StringUtils;importjava.net.Inet4Address;importjava.net.UnknownHostException;/***@Deacripti
- Java Xml 工具类
Jokes-T
javaxml
importorg.apache.commons.lang3.StringUtils;importorg.dom4j.Document;importorg.dom4j.DocumentException;importorg.dom4j.DocumentHelper;importorg.dom4j.Element;importjavax.xml.bind.JAXBContext;importjava
- base64和字符串的转换
乐之者v
A1-java代码块积累java
base64转换为字符串/***base64转字符串*@parambase64*@return*/publicstaticStringbase64ToStr(Stringbase64){if(StringUtils.isBlank(base64)){returnStringUtils.EMPTY;}byte[]bytes=Base64.getUrlDecoder().decode(base64.g
- SpringBoot后端接收文件转换成Base64保存到数据库
Sherlock_026
Javaspringbootjava后端
前言:若依前后端分离项目:SpringBoot+Vue前端上传文件(每次仅上传一个文件),后端接收文件(MultipartFile),将其转换为Base64,存储到数据库。新建一个工具类Base64Utils.javaimportcom.ruoyi.common.utils.StringUtils;importorg.apache.commons.codec.binary.Base64;impor
- StringUtils的isBlank和isEmpty等用法详解
指尖改变生活
工具类
**StringUtil里面的常用的方法:**1.publicstaticbooleanisBlank(Stringstr)在校验一个String类型的变量是否为空时,通常存在3中情况是否为null是否为“”是否为空字符串(引号中间有空格)如:""。制表符、换行符、换页符和回车StringUtils的isBlank()方法可以一次性校验这三种情况,返回值都是true,否则为false示例:Stri
- StringUtils工具类中isEmpty和isBlank的用法区别
桐花思雨
java#基础java
目录简述`org.apache.commons.lang3`中的`StringUtils``isEmpty`系列`isEmpty()`方法`isNotEmpty()`方法`isAnyEmpty()`方法`isNoneEmpty()`方法`isBlank`系列`isBlank()`方法`isNotBlank()`方法`isAnyBlank()`方法`isNoneBlank()`方法`isEmpty`
- StringUtils的isEmpty和StringUtils的isBlank的区别
JH3073
服务器apache
StringUtils.isEmptyStringUtils.isEmpty(Stringstr)方法用于检查传入的字符串是否为null或者空字符串(“”)。如果字符串是null或者空字符串,则返回true;否则返回false。示例:StringUtils.isEmpty(null);//返回trueStringUtils.isEmpty("");//返回trueStringUtils.isEmp
- springboot 集成 mybatis plus 在controller层实现的增删改查用法,以及spring boot 常用注解
奇纳尼
ideajavaspringbootrest
注意事项://注意:当使用参数@requestBody的时候,只支持post请求,所以只能用@PostMapping,当@requestBody里面的可以为空时候,设置required=false,//注意:StringUtils用org.springframework.util的可以判断StringUtils.isEmpty(Object),用common下面的只能字符串//注意:当我们在参数传
- java springboot 获取服务器真实IP访问地址
大白菜程序猿
JAVAjavaspringboot服务器
获取真实IP地址importjavax.servlet.http.HttpServletRequest;importorg.apache.commons.lang3.StringUtils;importorg.jeecg.common.constant.CommonConstant;publicclassIpUtils{/***获取IP地址**使用Nginx等反向代理软件,则不能通过request
- POI对Excel的读取操作
不会写爬虫的程序员B
poiexcel
//前端excel只需要直接提交form表单即可publicAjaxResultexcelAdd(@RequestPart("file")MultipartFilefile)throwsException{if(file.isEmpty()){returnAjaxResult.error("没有发现文件");}if(StringUtils.isNotBlank(file.getOriginalFi
- Java中的字符串转换工具类:StringUtils.camelToUnderline 方法详解
JonTang
Javajava
在Java开发中,经常会遇到需要转换字符串格式的场景。其中,驼峰命名法(CamelCase)和下划线命名法(SnakeCase)是两种常见的命名方式。为了方便在这两种命名方式之间进行转换,我们可以使用StringUtils.camelToUnderline方法,它是一个实用的字符串转换工具类。本篇博客将详细介绍StringUtils.camelToUnderline方法的原理、使用方法以及示例代码
- freemark中插入图片
wyazyf
代码freemark中插入图片freemark导出wordjava
freemark文件中的图片格式是BASE64,模板中的图片代码块,${(img)!}是图片变量${(img)!}生成${(img)!}图片变量(BASE64格式)publicStringgetEmpAutograph(StringfilePath){Stringimg=null;if(StringUtils.isNotEmpty(filePath)){InputStreamin=null;byt
- 递归读取文件夹下的所有文件
澄风
java遍历文件夹递归遍历文件夹下所有文件
水一篇文章代码packagefile;importorg.apache.commons.lang3.StringUtils;importorg.junit.Test;importjava.io.File;importjava.util.Objects;/***FlattenDirFiles**@authorallens*@date2024/2/19*/publicclassFlattenDirFi
- StringUtils工具
策马踏清风
StringUtils是一款字符串处理工具,这里列举了一下常用功能isEmpty(Stringstr)是否为空,空格字符为falseisNotEmpty(Stringstr)是否为非空,空格字符为trueisBlank(Stringstr)是否为空,空格字符为trueisNotBlank(Stringstr)是否为非空,空格字符为falsetrim(Stringstr)去除字符串两端的控制符,空字
- 2018-08-23 Java工具类——全角半角字符相互转换
Albert陈凯
https://blog.csdn.net/xyw591238/article/details/51719747https://my.oschina.net/zjcx/blog/679604https://segmentfault.com/a/1190000010841143importorg.apache.commons.lang.StringUtils;/****提供对字符串的全角->半角,半
- Spring Boot 获取接口调用者的IP
众纳
Springbootspringboot获取IPjava获取IPjava接口获取IP
需求:我们实现一个登陆功能时,可能会有需要记录登陆者IP的需求,用于系统安全分析或账户来源分析。(当然还有更多应用场景)工具类如下(来源于网络,已兼容K8S代理的情况)importorg.slf4j.Logger;importorg.slf4j.LoggerFactory;importorg.springframework.util.StringUtils;importjavax.servlet.
- nacos-client 推送和移除配置源码
chudaxiakkk
Nacos一路持之以恒
Stringurl=Constants.CONFIG_CONTROLLER_PATH;Mapparams=newHashMap(6);params.put("dataId",dataId);params.put("group",group);params.put("content",content);params.put("type",type);if(StringUtils.isNotEmpty
- java正则表达式获取json字符串中指定key的value
满脑子灵感
mysqllinux数据库
importorg.apache.commons.lang3.StringEscapeUtils;importorg.apache.commons.lang3.StringUtils;importjava.util.ArrayList;importjava.util.List;importjava.util.regex.Matcher;importjava.util.regex.Pattern;p
- Spring核心基础:全面总结Spring中提供的那些基础工具类!
程序员古德
springjava数据库
内容概要SpringFramework提供了众多实用的工具类,这些工具类在简化开发流程、提升代码质量和维护性方面发挥了重要作用,以下是部分关键工具类的总结及其使用场景:StringUtils:不仅提供了基础的字符串操作,如拼接、拆分、大小写转换,还包含了更高级的功能,如检查字符串是否为空或只包含空白字符,在开发中,这可以避免空指针异常,并简化字符串的预处理工作。CollectionUtils:当处
- StringUtils中 isNotEmpty 和isNotBlank的区别【java字符串判空】
移动端_小刚哥
原文地址:https://www.cnblogs.com/dixinyunpan/p/6088612.htmlisNotEmpty(str)等价于str!=null&&str.length>0isNotBlank(str)等价于str!=null&&str.length>0&&str.trim().length>0同理isEmpty等价于str==null||str.length==0isBlan
- 常用Java工具类:手机号脱敏,身份证号脱敏
阿咚do懂
常用Java工具类java开发语言后端
目录:1手机号脱敏2身份证号脱敏3姓名脱敏1手机号脱敏本案要求:手机号的保留前三后四,中间的为星号"*"//手机号码前三后四脱敏publicstaticStringmobileEncrypt(Stringmobile){if(StringUtils.isEmpty(mobile)||(mobile.length()!=11)){returnmobile;}returnmobile.replaceA
- 身份证、姓名、手机号、地址、邮箱脱敏处理
秃顶的程序媛
Java基础java
1、身份证脱敏:显示后4位publicstaticStringtmCardCode(StringcardId){if(null==cardId||cardId.length()3){tmName=StringUtils.right(name,2);}else{tmName=StringUtils.right(name,1);}tmName=StringUtils.leftPad(tmName,St
- 常用数字处理格式校验
微凉归期
7-日常工作总结javavue
1、前端校验1.1要求为数字类型(不限位数与正负)input输入框添加type=“number”当type=number时,仍然可以输入字母e或E。解决方法是:给type=number的输入框添加一个正则表达式:1.2要求为正整数(如学时、人数等)1.3要求为大于零且保留两位小数(如温度、金额等)2、后端校验2.1判断为正整数Stringvlaue="12356";if(StringUtils.i
- java组装复杂的map结构
lichongxyz
杂乱java开发语言
如下图数据库查出来的记录要组装成如下图所示的map结构。直接上代码packagecom.rt.test.other;importorg.apache.commons.lang.StringUtils;importjava.util.*;publicclassTestMap{publicstaticvoidmain(String[]args){Mapmap=newLinkedHashMaplist=
- javacv视频获取第一帧作为缩略图
一把青龙湾月刀
javajava
POM依赖org.bytedecojavacv-platform1.4.2package;importorg.apache.commons.io.IOUtils;importorg.apache.commons.lang3.StringUtils;importorg.bytedeco.javacv.FFmpegFrameGrabber;importorg.bytedeco.javacv.Frame
- 各类型判空操作
Bin哥厉害7
Java课堂java
开发中经常遇到需要判空的地方,比如对字符串进行判空操作。而有时候工具包太多不知道用哪个。就像下图,光一个StringUtils就有十几个包弹出来。怎么选?其实用哪个都行。最重要的是:有一套自己用的顺手的工具。或者换句话说:要养成自己的开发习惯。有了自己专属的开发习惯,不管客观上这个习惯是否是最优的,但一定要有一套,然后随着经验积累和实践,将这套习惯不断修整精进,达到个人开发效率的最高程度。而且更值
- 2019-08-01工作总结
Mr钧
1.源哥手把手教我写代码,真心感谢.2.源哥说:开发时一定要用debug调试代码,每一行都要走到,要确保实际和预期100%一致.所有分支都要走到,这样才能确保代码的健壮性3.bobussinessObject==>业务对象,就只在service层使用4.尽量不使用字段保存数据,因为一旦并发,就会冲突.5.每一行代码的功能要明确,并且单一.==>方便复用6.现在工具类很多,如StringUtils;
- apache 安装linux windows
墙头上一根草
apacheinuxwindows
linux安装Apache 有两种方式一种是手动安装通过二进制的文件进行安装,另外一种就是通过yum 安装,此中安装方式,需要物理机联网。以下分别介绍两种的安装方式
通过二进制文件安装Apache需要的软件有apr,apr-util,pcre
1,安装 apr 下载地址:htt
- fill_parent、wrap_content和match_parent的区别
Cb123456
match_parentfill_parent
fill_parent、wrap_content和match_parent的区别:
1)fill_parent
设置一个构件的布局为fill_parent将强制性地使构件扩展,以填充布局单元内尽可能多的空间。这跟Windows控件的dockstyle属性大体一致。设置一个顶部布局或控件为fill_parent将强制性让它布满整个屏幕。
2) wrap_conte
- 网页自适应设计
天子之骄
htmlcss响应式设计页面自适应
网页自适应设计
网页对浏览器窗口的自适应支持变得越来越重要了。自适应响应设计更是异常火爆。再加上移动端的崛起,更是如日中天。以前为了适应不同屏幕分布率和浏览器窗口的扩大和缩小,需要设计几套css样式,用js脚本判断窗口大小,选择加载。结构臃肿,加载负担较大。现笔者经过一定时间的学习,有所心得,故分享于此,加强交流,共同进步。同时希望对大家有所
- [sql server] 分组取最大最小常用sql
一炮送你回车库
SQL Server
--分组取最大最小常用sql--测试环境if OBJECT_ID('tb') is not null drop table tb;gocreate table tb( col1 int, col2 int, Fcount int)insert into tbselect 11,20,1 union allselect 11,22,1 union allselect 1
- ImageIO写图片输出到硬盘
3213213333332132
javaimage
package awt;
import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
import javax.imagei
- 自己的String动态数组
宝剑锋梅花香
java动态数组数组
数组还是好说,学过一两门编程语言的就知道,需要注意的是数组声明时需要把大小给它定下来,比如声明一个字符串类型的数组:String str[]=new String[10]; 但是问题就来了,每次都是大小确定的数组,我需要数组大小不固定随时变化怎么办呢? 动态数组就这样应运而生,龙哥给我们讲的是自己用代码写动态数组,并非用的ArrayList 看看字符
- pinyin4j工具类
darkranger
.net
pinyin4j工具类Java工具类 2010-04-24 00:47:00 阅读69 评论0 字号:大中小
引入pinyin4j-2.5.0.jar包:
pinyin4j是一个功能强悍的汉语拼音工具包,主要是从汉语获取各种格式和需求的拼音,功能强悍,下面看看如何使用pinyin4j。
本人以前用AscII编码提取工具,效果不理想,现在用pinyin4j简单实现了一个。功能还不是很完美,
- StarUML学习笔记----基本概念
aijuans
UML建模
介绍StarUML的基本概念,这些都是有效运用StarUML?所需要的。包括对模型、视图、图、项目、单元、方法、框架、模型块及其差异以及UML轮廓。
模型、视与图(Model, View and Diagram)
&
- Activiti最终总结
avords
Activiti id 工作流
1、流程定义ID:ProcessDefinitionId,当定义一个流程就会产生。
2、流程实例ID:ProcessInstanceId,当开始一个具体的流程时就会产生,也就是不同的流程实例ID可能有相同的流程定义ID。
3、TaskId,每一个userTask都会有一个Id这个是存在于流程实例上的。
4、TaskDefinitionKey和(ActivityImpl activityId
- 从省市区多重级联想到的,react和jquery的差别
bee1314
jqueryUIreact
在我们的前端项目里经常会用到级联的select,比如省市区这样。通常这种级联大多是动态的。比如先加载了省,点击省加载市,点击市加载区。然后数据通常ajax返回。如果没有数据则说明到了叶子节点。 针对这种场景,如果我们使用jquery来实现,要考虑很多的问题,数据部分,以及大量的dom操作。比如这个页面上显示了某个区,这时候我切换省,要把市重新初始化数据,然后区域的部分要从页面
- Eclipse快捷键大全
bijian1013
javaeclipse快捷键
Ctrl+1 快速修复(最经典的快捷键,就不用多说了)Ctrl+D: 删除当前行 Ctrl+Alt+↓ 复制当前行到下一行(复制增加)Ctrl+Alt+↑ 复制当前行到上一行(复制增加)Alt+↓ 当前行和下面一行交互位置(特别实用,可以省去先剪切,再粘贴了)Alt+↑ 当前行和上面一行交互位置(同上)Alt+← 前一个编辑的页面Alt+→ 下一个编辑的页面(当然是针对上面那条来说了)Alt+En
- js 笔记 函数
征客丶
JavaScript
一、函数的使用
1.1、定义函数变量
var vName = funcation(params){
}
1.2、函数的调用
函数变量的调用: vName(params);
函数定义时自发调用:(function(params){})(params);
1.3、函数中变量赋值
var a = 'a';
var ff
- 【Scala四】分析Spark源代码总结的Scala语法二
bit1129
scala
1. Some操作
在下面的代码中,使用了Some操作:if (self.partitioner == Some(partitioner)),那么Some(partitioner)表示什么含义?首先partitioner是方法combineByKey传入的变量,
Some的文档说明:
/** Class `Some[A]` represents existin
- java 匿名内部类
BlueSkator
java匿名内部类
组合优先于继承
Java的匿名类,就是提供了一个快捷方便的手段,令继承关系可以方便地变成组合关系
继承只有一个时候才能用,当你要求子类的实例可以替代父类实例的位置时才可以用继承。
在Java中内部类主要分为成员内部类、局部内部类、匿名内部类、静态内部类。
内部类不是很好理解,但说白了其实也就是一个类中还包含着另外一个类如同一个人是由大脑、肢体、器官等身体结果组成,而内部类相
- 盗版win装在MAC有害发热,苹果的东西不值得买,win应该不用
ljy325
游戏applewindowsXPOS
Mac mini 型号: MC270CH-A RMB:5,688
Apple 对windows的产品支持不好,有以下问题:
1.装完了xp,发现机身很热虽然没有运行任何程序!貌似显卡跑游戏发热一样,按照那样的发热量,那部机子损耗很大,使用寿命受到严重的影响!
2.反观安装了Mac os的展示机,发热量很小,运行了1天温度也没有那么高
&nbs
- 读《研磨设计模式》-代码笔记-生成器模式-Builder
bylijinnan
java设计模式
声明: 本文只为方便我个人查阅和理解,详细的分析以及源代码请移步 原作者的博客http://chjavach.iteye.com/
/**
* 生成器模式的意图在于将一个复杂的构建与其表示相分离,使得同样的构建过程可以创建不同的表示(GoF)
* 个人理解:
* 构建一个复杂的对象,对于创建者(Builder)来说,一是要有数据来源(rawData),二是要返回构
- JIRA与SVN插件安装
chenyu19891124
SVNjira
JIRA安装好后提交代码并要显示在JIRA上,这得需要用SVN的插件才能看见开发人员提交的代码。
1.下载svn与jira插件安装包,解压后在安装包(atlassian-jira-subversion-plugin-0.10.1)
2.解压出来的包里下的lib文件夹下的jar拷贝到(C:\Program Files\Atlassian\JIRA 4.3.4\atlassian-jira\WEB
- 常用数学思想方法
comsci
工作
对于搞工程和技术的朋友来讲,在工作中常常遇到一些实际问题,而采用常规的思维方式无法很好的解决这些问题,那么这个时候我们就需要用数学语言和数学工具,而使用数学工具的前提却是用数学思想的方法来描述问题。。下面转帖几种常用的数学思想方法,仅供学习和参考
函数思想
把某一数学问题用函数表示出来,并且利用函数探究这个问题的一般规律。这是最基本、最常用的数学方法
- pl/sql集合类型
daizj
oracle集合typepl/sql
--集合类型
/*
单行单列的数据,使用标量变量
单行多列数据,使用记录
单列多行数据,使用集合(。。。)
*集合:类似于数组也就是。pl/sql集合类型包括索引表(pl/sql table)、嵌套表(Nested Table)、变长数组(VARRAY)等
*/
/*
--集合方法
&n
- [Ofbiz]ofbiz初用
dinguangx
电商ofbiz
从github下载最新的ofbiz(截止2015-7-13),从源码进行ofbiz的试用
1. 加载测试库
ofbiz内置derby,通过下面的命令初始化测试库
./ant load-demo (与load-seed有一些区别)
2. 启动内置tomcat
./ant start
或
./startofbiz.sh
或
java -jar ofbiz.jar
&
- 结构体中最后一个元素是长度为0的数组
dcj3sjt126com
cgcc
在Linux源代码中,有很多的结构体最后都定义了一个元素个数为0个的数组,如/usr/include/linux/if_pppox.h中有这样一个结构体: struct pppoe_tag { __u16 tag_type; __u16 tag_len; &n
- Linux cp 实现强行覆盖
dcj3sjt126com
linux
发现在Fedora 10 /ubutun 里面用cp -fr src dest,即使加了-f也是不能强行覆盖的,这时怎么回事的呢?一两个文件还好说,就输几个yes吧,但是要是n多文件怎么办,那还不输死人呢?下面提供三种解决办法。 方法一
我们输入alias命令,看看系统给cp起了一个什么别名。
[root@localhost ~]# aliasalias cp=’cp -i’a
- Memcached(一)、HelloWorld
frank1234
memcached
一、简介
高性能的架构离不开缓存,分布式缓存中的佼佼者当属memcached,它通过客户端将不同的key hash到不同的memcached服务器中,而获取的时候也到相同的服务器中获取,由于不需要做集群同步,也就省去了集群间同步的开销和延迟,所以它相对于ehcache等缓存来说能更好的支持分布式应用,具有更强的横向伸缩能力。
二、客户端
选择一个memcached客户端,我这里用的是memc
- Search in Rotated Sorted Array II
hcx2013
search
Follow up for "Search in Rotated Sorted Array":What if duplicates are allowed?
Would this affect the run-time complexity? How and why?
Write a function to determine if a given ta
- Spring4新特性——更好的Java泛型操作API
jinnianshilongnian
spring4generic type
Spring4新特性——泛型限定式依赖注入
Spring4新特性——核心容器的其他改进
Spring4新特性——Web开发的增强
Spring4新特性——集成Bean Validation 1.1(JSR-349)到SpringMVC
Spring4新特性——Groovy Bean定义DSL
Spring4新特性——更好的Java泛型操作API
Spring4新
- CentOS安装JDK
liuxingguome
centos
1、行卸载原来的:
[root@localhost opt]# rpm -qa | grep java
tzdata-java-2014g-1.el6.noarch
java-1.7.0-openjdk-1.7.0.65-2.5.1.2.el6_5.x86_64
java-1.6.0-openjdk-1.6.0.0-11.1.13.4.el6.x86_64
[root@localhost
- 二分搜索专题2-在有序二维数组中搜索一个元素
OpenMind
二维数组算法二分搜索
1,设二维数组p的每行每列都按照下标递增的顺序递增。
用数学语言描述如下:p满足
(1),对任意的x1,x2,y,如果x1<x2,则p(x1,y)<p(x2,y);
(2),对任意的x,y1,y2, 如果y1<y2,则p(x,y1)<p(x,y2);
2,问题:
给定满足1的数组p和一个整数k,求是否存在x0,y0使得p(x0,y0)=k?
3,算法分析:
(
- java 随机数 Math与Random
SaraWon
javaMathRandom
今天需要在程序中产生随机数,知道有两种方法可以使用,但是使用Math和Random的区别还不是特别清楚,看到一篇文章是关于的,觉得写的还挺不错的,原文地址是
http://www.oschina.net/question/157182_45274?sort=default&p=1#answers
产生1到10之间的随机数的两种实现方式:
//Math
Math.roun
- oracle创建表空间
tugn
oracle
create temporary tablespace TXSJ_TEMP
tempfile 'E:\Oracle\oradata\TXSJ_TEMP.dbf'
size 32m
autoextend on
next 32m maxsize 2048m
extent m
- 使用Java8实现自己的个性化搜索引擎
yangshangchuan
javasuperword搜索引擎java8全文检索
需要对249本软件著作实现句子级别全文检索,这些著作均为PDF文件,不使用现有的框架如lucene,自己实现的方法如下:
1、从PDF文件中提取文本,这里的重点是如何最大可能地还原文本。提取之后的文本,一个句子一行保存为文本文件。
2、将所有文本文件合并为一个单一的文本文件,这样,每一个句子就有一个唯一行号。
3、对每一行文本进行分词,建立倒排表,倒排表的格式为:词=包含该词的总行数N=行号