你键入 date,日期和时间将以一种有用的方式显示。...它包括星期几、日期、时间和时区: $ date Tue 26 Nov 2019 11:45:11 AM EST 只要你的系统配置正确,你就会看到日期和当前时间以及时区。...但是,该命令还提供了许多选项来以不同方式显示日期和时间信息。...例如,如果要显示日期以便进行排序,则可能需要使用如下命令: $ date "+%Y-%m-%d" 2019-11-26 在这种情况下,年、月和日按该顺序排列。...假设你需要创建一个每日报告并在文件名中包含日期,则可以使用以下命令来创建文件(可能用在脚本中): $ touch Report-`date "+%Y-%m-%d"` 当你列出你的报告时,它们将按日期顺序或反向日期顺序
可以添加一个日期 x时间和一个持续时间来计算一个新的日期时间,它与线性时间轴上的距离正好是 的大小。在这里,datetime代表, , , or 中的任何一个,并且非空结果将是相同的类型。...可以按如下方式计算日期时间偏移的持续时间:yx + yxyDateDateTimeDateTimeZoneTime 如果指定了日期时间自纪元值以来的天数,则使用以下信息元素构造一个新的日期时间: 计算自纪元以来的新天数...如果未指定日期时间自纪元值以来的天数,请使用指定的以下信息元素构建新的日期时间: 计算自午夜以来的新滴答声,相当于将 y 的大小添加到自午夜起 x 的滴答声中,以 24 小时周期内 100 纳秒滴答声的数量为模...duration(1,0,0,0) //#datetime(2010, 10, 11, 0, 0, 0, 0, 0) //2010-10-11T00:00:00+00:00 以下示例显示了按给定时间的持续时间计算日期时间偏移量...在这里,日期时间代表任何的date,datetime,datetimezone,或time。生成的日期x时间与线性时间轴上的距离正好是 的大小y,在 的符号相反的方向上y。
在实际业务开发中,可能会遇到Java Map按值排序的需要。...Java Map按值排序的常见思路是: 1、 将map中的entry放到List中 2、 对List中的entry通过比较器按值排序 3 、将排序后的entry放到linkedhashmap中 Java...e1, e2) -> e2, LinkedHashMap::new)); System.out.println("升序按值排序后的...e1, e2) -> e2, LinkedHashMap::new)); System.out.println("降序按值排序后的...LinkedList >(hm.entrySet()); // 对List按entry的value排序 Collections.sort(list, new Comparator >()
Java 8 Java8中我们可以使用新的日期对象,这类API给我们提供了,自动处理、不可变、流畅和线程安全的日期处理对象。...这些API让我们不需要借助工具类如java.util.Calendar 的情况下就可以实现日期的自增。...Java 9+ Java9的日期类中的datesUntil支持用Stream方式对日期进行迭代。 下面我们用此特性对上面代码进行升级。...结论 上面是Java日期迭代的快速上手教程。 Java8以后对日期的迭代越来越方便。 注意Java7和之前的版本,虽然只需要日期,也要同时处理时间和日期。...Java8和之后的版本中,我们可以根据需要选择对应的日期类如LocalDate, LocalDateTime等。 Java9中日期API和Stream可以结合使用。
遍历数据有以下三种方法: 简单对上面三种方法进行说明: iterrows(): 按行遍历,将DataFrame的每一行迭代为(index, Series)对,可以通过row[name]对元素进行访问。...itertuples(): 按行遍历,将DataFrame的每一行迭代为元祖,可以通过row[name]对元素进行访问,比iterrows()效率高。...iteritems():按列遍历,将DataFrame的每一列迭代为(列名, Series)对,可以通过row[index]对元素进行访问。...iterrows(): for index, row in df.iterrows(): print(index) # 输出每行的索引值 1 2 row[‘name’] # 对于每一行,通过列名...name访问对应的元素 for row in df.iterrows(): print(row[‘c1’], row[‘c2’]) # 输出每一行 1 2 3 按行遍历itertuples()
在实际的开发中,我们常常会用到工具类去拷贝对象的属性,将一个对象的属性转换成另外一个对象的属性值。首先:答应我不要去自己重复造轮子,写Beanutil了,为什么不去使用现成的工具类呢?...现成的工具类简单又安全,自己写的万一哪天出了问题呢。 这里的beanUtil 我首推hutool,它的工具类的真的太丰富了,真的感觉它太懂中国的程序员了。...hutool官方的解释是这样的: 属性拷贝选项 包括: 1、限制的类或接口,必须为目标对象的实现接口或父类,用于限制拷贝的属性,例如一个类我只想复制其父类的一些属性,就可以将editable设置为父类...我们将它的可以set的属性全部的设置一下。...这个在实际的开发中还是很实用的,具体场景具体的分析。 和之前一样,代码案例在shigen的gitee上,感兴趣的伙伴可以自行去查看。
下图就是一个常见的反例: 为了视觉效果的简洁,可以默认状态可以不展示拖拽隐喻,但悬停时一定要有拖拽隐喻。 点阵图标是现在最主流方式,不论移动端还是桌面端都通用。...下图是优化后正确的效果: 通过图标和指针,也能暗示拖动的方向,减少学习成本。 2. 拖拽状态 拖拽过程中,主要有两方面问题需要解决:拖拽对象不突出和拖拽对象遮挡背景,以下反例中都能体现。...下图是优化后正确的效果: 3. 目标暗示 有的拖拽交互,目标不明确,第一次使用很难理解。 例如下图,你不确定是不是可以拖到灰色背景处。...下图是优化后正确的效果: 6. 选中状态 不知道大家有没有过这样的经历,把一个东西拖拽到另一个地方,拖完后就忘记刚刚拖的是什么了。 尤其是在这过程中页面还跳动一下,就完全找不着北了。...如果拖动操作较为复杂,涉及的对象多,就建议增加这个选中态,方便查找。 下图是优化后正确的效果: 选中状态不太适合用在移动端,但移动端本身也不适合复杂的拖拽操作。
类BigDecimal,用来对超过16位有效位的数进行精确的运算。...BigDecimal所创建的是对象,故我们不能使用传统的+、-、*、/等算术运算符直接对其对象进行数学运算,而必须调用其相对应的方法。方法中的参数也必须是BigDecimal的对象。...构造器是类的特殊方法,专门用来创建对象,特别是带有参数的对象。...首先,创建BigDecimal对象,进行BigDecimal的算术运算后,分别建立对货币和百分比格式化的引用,最后利用BigDecimal对象作为format()方法的参数,输出其格式化的货币值和百分比...BigDecimal都是不可变的(immutable)的, 在进行每一次四则运算时,都会产生一个新的对象 ,所以在做加减乘除运算时要记得要保存操作后的值。
缘起 架构分层 开发分布式的项目时,DO持久化对象和DTO传输对象的转换是不可避免的。...其二,远程调用需要额外注意网络传输的开销,如果生产者方从数据库加载出了一个一对多的依赖,而消费者只需要一这个实体的某个属性,多的实体会使得性能产生下降,并没有很好的方式对其进行控制(忽略手动set)。...便引出了今天的主角:Orika。 Orika是什么?...具有相同的地位,负责对象间的映射,也是实际使用中,我们使用的最多的类。...可以看到几乎每个方法都传入了一个Type,用于获取拷贝类的真实类型,而不是传入.class字节码,下面介绍正确的打开姿势: @Testpublic void genericTest1() { MapperFactory
按钮样式的正确方式 如果你正在建立一个网站或一个web应用,你可能会用到按钮,也许看起来像按钮的链接。不管怎样,让这些正常展示是很重要的。...使用正确的元素有几个优点:它对搜索引擎友好(尤其是链接!),它适用于键盘导航,它提高了所有用户的可访问性。 尽管如此,开发人员很少使用元素。...对于其他人来说,使用鼠标或触摸指针是不可能的或困难的。 他们依靠使用键盘或专用设备访问网站。 在我见过的大多数Web项目中,设计师都指定了预期的鼠标移过样式,但未指定焦点样式。 我们应该做什么?...处理focus样式 还有一个棘手的问题。 在多个浏览器中,当您单击链接或按钮时,将应用两个伪类: :active :focus 一旦停止按下鼠标按钮或触控板,“active”伪类就会停止应用。...不是活动的(例如,如果我们的JS未能加载),则会中断焦点样式。
原文作者:ipfans 今天正好看到一篇关于敏感信息过滤的文章,这算做一个interface实际应用的一些举例和应用。...文中提及了json.Unmarshaler接口一个方法,但这种方法并不是完全能够解决所有的类型的敏感信息过滤问题。比如在使用调试过程中,开发人员常常使用的fmt/log包,则不能用这种方法解决。...实际上,我个人认为非常合适的方法是,我们可以特定某个特殊类型Sensitivity,对于敏感信息统一采用这个类型予以保护。这样也方便我们后续添加新的保护方式。...我们结合第一个方法中的json.Unmarshaler一起使用时,那么就是一个比较完整的敏感信息过滤方案了。...(s Sensitivity) MarshalJSON() ([]byte, error) { 6 return []byte(`"[SENSITIVE DATA]"`), nil 7} 这种方式也能很好的兼容各种数据库
前言 需求就是想把wgs84的地理坐标转换成2000的投影坐标,在网上看的方法但是会报错,说是ArcGIS10.5的问题,今天试了下10.2的版本可以了,所以记录下过程,免得以后忘记了。
一、旁路由的配置 上图是旁路由的连接方式,一般作为旁路由的只有一个LAN口,可以把它想成一个普通的连接路由器的电脑。...这样配置后,网络流量变成下图了: 这样旁路由其实就是一个没有路由功能的二级路由器了,你会发现在你迅雷等高速下载的时候旁路由的cpu会异常的高,都用来nat了,而不是最初旁路由的目的–只加解密科学流量。...查看有没有设置正确的方法很简单 1.迅雷等高速下载的时候看cpu占用是不是很高 2.比较靠谱的一种,看上下行的流量,正确配置的话,旁路由的上行是大于下行的,如果上下相同且数据流量很大(高速下载时候比较明显...这是下载速度: 正确配置的上下行速度和cpu占用: 错误配置的上下行速度和cpu占用: 3.最最靠谱的是去主路由看联网设备信息,会发现该设备的ip是电脑的,但是mac地址是软路由的 当然,如果用的主路由是华为...、小米、360等,那没辙,只能用上述加防火墙规则或者加wan口,采用nat的方式避免它的检验(这样还不如弄成二级路由省时省心),或者换一个主路由器。
Shapefile文件简介 Shapefile文件是美国ESRI公司发布的文件格式,因其ArcGIS软件的推广而得到了普遍的使用,是现在GIS领域使用最为广泛的矢量数据格式。...官方称Shapefile是一种用于存储地理要素的几何位置和属性信息的非拓扑简单格式。 一般地,Shapefile文件是多个文件的集合,至少包括一个shp,shx以及dbf文件。...shx索引文件用于存储几何数据的索引信息,包含对主文件中每个记录长度的描述(注意不是空间索引) dbf表文件是使用dBase数据库表文件进行空间属性数据存储的文件 所以,我们如果要自己完全从底层写代码解析...Shapefile文件的话,需要根据shx文件中的信息读取shp中的二进制数据并转化为几何对象,然后再读取dbf表格,将属性添加到几何对象上就完成了对一个Shapefile文件的解析....GDAL中的空间要素模型是按照OGC的Simple Feature规范实现的,有兴趣的童鞋可以参考官方文档:Simple Feature Access 使用GDAL打开Shapefile文件 下面的例子演示了如何打开
博客: http://www.cnblogs.com/webRobot ❈—— ——此文以纪念南京大屠杀79周年 今天Toby教你如何用python的basemap包绘制轰炸东京的地图。...在数据可视化过程中,我们常常需要将数据根据其采集的地理位置在地图上显示出来。比如说我们会想要在地图上画出城市,飞机的航线,乃至于军事基地等等。通常来说,一个地理信息系统都会带有这样的功能。...今天我们讨论如何在Python上实现,并且使用免费的工具包。 matplotlib是Python常用的数据绘制包。它基于numpy的数组运算功能。...他们是免费工具,但其功能足可以与科研界的大佬Matlab竞争。 Basemap是Matplotlib的一个子包,负责地图绘制。在数据可视化过程中,我们常需要将数据在地图上画出来。...这样的地理绘图有助于读者理解空间相关的信息。
youtube这个不存在的网站上有很多有用的资料,一般来说我们是可以下载所有视频到本地以供离线的情况下的研究学习,网上有很多工具提供了下载功能,但是在试用了很多标称很好用的软件后,老高发现,真的没有一个能和...youtube-dl相提并论,所以老高还是记录一下如何使用正确使用youtube-dl!
1.插入节点,在已知节点 b 的前面插入 x ? 接口定义 首先我们定义链表的基本接口,为了显示出 B 格,我们模仿我们 Java 中的 List 接口定义。...,一个用于保存当前节点的数据 item,另外一个则是 指向下一个节点的 next 指针。...,否则需要找到当前链表指定位置的节点元素,并在该元素前面插入新的节点数据,重新组织两者节点的 next指针。...这里的删除比较复杂,老铁们记得多画图来辅助理解,防止出现指针指向错误造成意想不到的结果。...,我们一定要多写才能掌握指针打断的正确操作,尤其是在删除操作最复杂。
互联网的大数据时代,网络爬虫的工作离不开大数据。在我们使用网络过程中,肯定遇到过访问网站IP受限这种问题。...其实不是你的IP出现了问题,而是对方因为目标网站的服务器的限制,限制了多次注册,多次访问,才会限制本地IP。...当然网上的免费代理IP也同样可以使用,免费代理IP的获取方式非常简单,直接通过网络搜索,然后网络爬虫编程一个程序来筛选可用的IP,免费的代理IP虽然很多,但是也只适合业务较小的用户,对IP质量要求不高的用户...不仅会影响业务的进展,爬虫效果也不会稳定。 对于大工作量的爬虫来说,效率是第一位的,只有高效率才能在有限的时间里,完成大量的工作。...要提高效率,则必须要高质量稳定的代理IP像公司企业对IP需求量大的网络爬虫用户,完全可以使用隧道转发的爬虫代理加强版,来提高业务的进展,加强业务的稳定性,不仅节约了业务时间,也能保证代理的正常运行,满足的大量客户的需求
最近在数据库处理的时候发现日期对比的时候没有返回正确的结果。 但是保存的时间实际上是相同的。 代码如下: if (!...问题解决 经过 Debug 后,这 2 个日期的纳秒数是不同的,查看下对象如下。 我们会发现其中一个对象有纳秒,一个对象没有。 但是 fastTime 是相同的。...如果使用 equals 那么这个方法比较的是毫秒,所以是不相等的。 因为多了一个 0。 如上图显示的毫秒比较,因此这里不能使用这个比较方法。...dbDateTime.isEqual(mlsDateTime)) { } 说白了这个问题就是精度的问题。 https://www.ossez.com/t/java/13833
项目场景: 线程池的地方用的还是挺多的,一般来说用的多的还是execute方法,submit方法还是用的挺少的,一般ThreadPoolExecutor 的 submit 方法通常用于将一个任务提交到线程池中执行...).append(queue.size()); } return info.toString(); } ---- 原因分析: 提示:跑了一次看到日志按照单线程的方式执行...:34 INFO UtilsTest :123 - thread name start:command-thread-4======== 原来submit的方式用错了...最后只能修改业务逻辑,因为对执行结果不是特别需求,所有可以改成execute方式,当然如果逻辑对返回值的需求特别的可以解耦,使用生产者消费者模式,一边计算一边处理,实现逻辑可以这样,在submit...总结 习惯了用execute就忘记了submit的正确使用方式,惯性是很恐怖的,还是得多多跑跑单元测试。
领取专属 10元无门槛券
手把手带您无忧上云