在 varchar 数据类型中放置“-”时遇到问题。. 需要是在最后两位数之后我们需要输入“-”,然后在两位数之后再次输入,依此类推。
输入字符串是- 21220 输出字符串- 2-12-20
或者,
输入字符串- 311220 输出字符串- 31-12-20
谁可以帮我这个事 ?
在 varchar 数据类型中放置“-”时遇到问题。. 需要是在最后两位数之后我们需要输入“-”,然后在两位数之后再次输入,依此类推。
输入字符串是- 21220 输出字符串- 2-12-20
或者,
输入字符串- 311220 输出字符串- 31-12-20
谁可以帮我这个事 ?
我会使用脚本组件来进行字符串操作,因为它更容易操作并且更具可读性。
1) 添加脚本组件作为转换
2)在输入列下,检查您的日期列(我在下面的示例中将此称为 myDate)
3) 在 Inputs and Outputs 下的 Output 0 下,为新日期添加一列,下面称为 formattedDate
4) 在脚本中,修改 Input0_ProcessInputRow 方法。在解析字符串之前,请确保它不为空。然后在左边用“0”填充它以确保我们的长度始终为 6。解析日期元素并为新列设置值。
public override void Input0_ProcessInputRow(Input0Buffer Row)
{
if (!Row.mydate_IsNull)
{
var paddedDate = Row.mydate.PadLeft(6, '0');
var day = paddedDate.Substring(0, 2);
var month = paddedDate.Substring(2, 2);
var year = paddedDate.Substring(4, 2);
Row.formattedDate = $"{day}-{month}-{year}";
}
}
(DT_WSTR, 2)(DT_I4)LEFT(RIGHT("0" + @[User::date], 6), 2) + "-" + SUBSTRING(RIGHT("0" + @[User::date], 6), 3, 2) + "-" + RIGHT(@[User::date] , 2)