我正在尝试让脚本组件为我正在处理的 HRIS 包工作。我收到一个不可调用的错误。我不熟悉 C#,所以我不知道如何纠正这个问题。我正在与一个油炸食品合作,该油炸食品改变了另一个 STO 成员之前给我的代码。
长度(); 是导致冲突的原因,“for”语句末尾的“i”也是如此。
修改后的代码如下。
/* Microsoft SQL Server Integration Services Script Component
* Write scripts using Microsoft Visual C# 2008.
* ScriptMain is the entry point class of the script.*/
using System;
using System.Data;
using Microsoft.SqlServer.Dts.Pipeline.Wrapper;
using Microsoft.SqlServer.Dts.Runtime.Wrapper;
using System.Text.RegularExpressions;
[Microsoft.SqlServer.Dts.Pipeline.SSISScriptComponentEntryPointAttribute]
public class ScriptMain : UserComponent
{
public override void PreExecute()
{
base.PreExecute();
/*
Add your code here for preprocessing or remove if not needed
*/
}
public override void PostExecute()
{
base.PostExecute();
/*
Add your code here for postprocessing or remove if not needed
You can set read/write variables here, for example:
Variables.MyIntVar = 100
*/
}
public override void Input0_ProcessInputRow(Input0Buffer Row)
{
const string pFirstName = @"^[A-Z]([-']?[a-z]+)*";
const string pSuffix = @"((Jr|Sr|I|V|X)( ?))+";
const string pInitial = @"(?<=\s)[A-Z](?=\s)";
const string pLastName = @"(?!(?:Jr|Sr|I|V|X|^))([A-Z][-'\s]?[a-z]+)";
string fullName = Row.Name.ToString();
string firstName = Regex.Match(fullName, pFirstName).Value;
string suffix = Regex.Match(fullName, pSuffix).Value;
string initial = Regex.Match(fullName, pInitial).Value;
string lastName = Regex.Match(fullName, pLastName).Value;
/*
* 20130708 - Edited by Armando Allison
*
*
* 1. Get the length of the entire full name
* 2. Get the firstName length value
* 3. Get the initial length value
* 4. Get the suffix length value
* 5. Get the lastName length value
*
*
*/
int length_full = fullName.Length(); //length of fullName
int length_first = firstName.Length(); //length of the firstName
int length_suffix = suffix.Length(); //length of the suffix
int length_initial = initial.Length(); // length of the initial
int length_lastName = lastName.Length(); //length of the lastName
int compare_length = 0;
compare_length = length_full - (length_first - length_initial - length_suffix); // if it pulled the data correctly, lastName length should equal compare_length
if (length_lastName == compare_length)
{
if (!string.IsNullOrEmpty(initial))
lastName += " " + initial;
if (!string.IsNullOrEmpty(suffix))
lastName += " " + suffix;
Row.FirstName = firstName;
Row.LastName = lastName;
}
else
{
// if the lastName doesnt match the compare_length
// you will have to do some more editing.
// 1. put entire full name into a string array
// 2. remove all the suffix, initial, and firstName
// 3. then output the entire lastName in a for loop with the remaining full name array
// remove to remove the other parts of the array that is not needed
// Pseudo code
char[] entire_name;
entire_name = new char[length_full];
entire_name = fullName.ToCharArray(0, length_full);
for (i = compare_length; i < length_full - 1; i++)
{
lastName = (String)entire_name[i];
}
// loop entire array to include the entire full name
// next remove the parts of the array that is not needed
// then output just the last name with another for loop
}
}
}