- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们需要生成 Excel 文件,单元格值应在公式栏中显示为 mm/dd/yyyy 格式 (1/1/1901),并显示与 yyyy-mm-dd 格式相同 (1901- 01-01) 在相应的单元格中。有人可以帮助一下如何使用 Perl 来实现这一点吗?请引用下面的屏幕截图,它将显示我们如何需要。
我们正在使用模块 Excel::Writer::XLSX 并尝试了以下代码,但它在公式栏和单元格中显示相同的格式。
if ($cell =~ qr[^(\d{4})/(\d{1,2})/(\d{1,2})$])
{
my $format1 = $workbook->add_format(num_format => 'yyyy-mm-dd');
my $date = sprintf "%02d/%02d/%04d", $2, $3, $1;
$worksheet->write_date_time( $iR, $iC, ${date}, $format1);
}
屏幕截图
最佳答案
来自文档:
The most direct way is to convert your dates to the ISO8601 yyyy-mm-ddThh:mm:ss.sss date format and use the write_date_time() worksheet method:
演示:
use strict;
use warnings;
use Excel::Writer::XLSX;
my $wb = Excel::Writer::XLSX->new( 'perl.xlsx' );
my $ws = $wb->add_worksheet();
$ws->set_column('A:B', 25);
my $date_format = $wb->add_format(num_format => 'yyyy-mm-dd');
my($d,$m,$y) = (20,1,1901);
#your current
my $current = sprintf "%02d/%02d/%04d", $d,$m,$y;
$ws->write('A1', 'using: %02d/%02d/%04d');
$ws->write_date_time( 'B1', $current, $date_format );
#you want
my $wanted = sprintf "%04d-%02d-%02dT", $y,$m,$d;
$ws->write('A2', 'using: %04d-%02d-%02dT');
$ws->write_date_time( 'B2', $wanted, $date_format );
在 Excel 中生成
关于excel - 如何使用perl将Excel单元格值在公式栏中显示为 "1/1/1901"并在相应单元格中显示与 "1901-01-01"相同,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43201509/
我在让我的操作栏显示图标时遇到问题。它显示了我在溢出菜单中设置的文本/标题(三个点),但没有任何操作。这是我的代码,我错过了什么? MainActivity.java public class Mai
我正在尝试在 android 中制作一个动态操作栏,现在我正在尝试像这样在操作栏中进行搜索。 http://developer.android.com/images/ui/actionbar-sear
我正在编写 uiautomator 测试,但我很难弄清楚如何单击我的操作栏图标。 如果我的操作是“始终”显示,则很容易找到并点击。 如果我的操作是显示“从不”,我必须单击菜单,然后从菜单中单击。先点击
我有一个正在寻找特定 URI 的重写规则。当它匹配特定的 URL 时,它会使用正确的文件路径重写它,以便可以找到所需的内容。然后它将协议(protocol)更改为 HTTPS 并允许请求通过。 我有两
我正在为 android 中的 ActionBar 而苦苦挣扎。 这是我的问题:我的操作项没有显示在操作栏中,而是堆叠在操作溢出中,无论我做什么.. 我花了一天的时间寻找解决方案,但我似乎找不到缺少的
我的网络应用程序在 Tomcat 下运行,它非常密集地使用 AJAX 请求,在开发过程中我也必须密集地重新部署网络应用程序。重新部署后,我通常会简单地刷新页面,知道用户 session 已删除,但我总
我是一名优秀的程序员,十分优秀!