0

我正在尝试让脚本组件为我正在处理的 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




    }



}

}  
4

7 回答 7

10

Length()不是方法,而是属性。只需使用Length不带括号即可。

于 2013-07-09T16:11:09.570 回答
5

编译错误对我来说似乎很清楚。这:

int length_full = fullName.Length();

应该:

int length_full = fullName.Length;

...同样适用于您的其他产品线。这是因为String.Length是属性,而不是方法。

除了修复代码之外,您应该再次查看编译错误并尝试找出您发现它令人困惑的原因 - 这可能会帮助您找出您应该更熟悉的 C# 部分。我强烈建议您先熟悉 C# 的基础知识,然后再将其他东西(例如数据库)弄得一团糟——这将使以后诊断任何问题变得容易得多。

于 2013-07-09T16:11:39.763 回答
5

Length字符串类型的属性,因此请删除括号。只需致电:

suffix.Length;

for(int i = compare_length; i < length_full - 1; i++)
{
     //Do something
}

因为您必须将 i 定义为循环内的 int 。

加,

lastName = (String)entire_name[i];是错的

采用 :

lastName = entire_name[i].ToString();
于 2013-07-09T16:13:33.873 回答
3

Length是一个属性,而不是一个方法,你可以省略()

int length_full = fullName.Length;
于 2013-07-09T16:11:16.590 回答
3

Length是属性,不是函数。只需删除括号。

于 2013-07-09T16:11:23.353 回答
0

for循环问题末尾的“i”应该可以通过将循环声明替换为来修复

for(int i = compare_length; i < length_full - 1; i++)
于 2013-07-09T16:14:21.640 回答
0

仅使用下面显示的 Length 而不是 Length() 它的 not 方法。

fullName.Length;
于 2013-07-09T16:14:46.170 回答