Перерыв на пробел, текстовое поле (конкретное условие) - PullRequest
0 голосов
/ 23 ноября 2011

Мне нужно разбить на ближайший пробел 30-й символ texbox, и я получил очень хороший ответ на этот вопрос:

var x = 30;
if (textBox1.Text.Length > x) 
{
    var index = textBox1.Text.Select((c, i) => new {c, i}).TakeWhile(q => q.i < x).Where(q => q.c == ' ' ).Select(q => q.i).Last(); 
    textBox1.Text = textBox1.Text.Insert(index, Environment.NewLine);
} 

Единственная проблема заключается в том, что мне нужно исключить из подсчета таких символов, как "@A", "@B", потому что они используются для форматирования текста.

Ответы [ 4 ]

0 голосов
/ 28 ноября 2011
        string oriText = textBox1.Text;//Original text that you input
        int charPerLine = 30;//Number of character per line
        string sKeyword = "@A|@B";//You can add more template here, the separator is "|"
        string[] arrKeyword = sKeyword.Split(new char[] { '|' }, StringSplitOptions.RemoveEmptyEntries);
        ArrayList arrListKeyword = new ArrayList();
        for (int i = 0; i < arrKeyword.Length; i++)
        {
            arrListKeyword.Add(" " + arrKeyword[i] + " ");
            arrListKeyword.Add(arrKeyword[i] + " ");
            arrListKeyword.Add(" " + arrKeyword[i]);
            arrListKeyword.Add(arrKeyword[i]);
        }
        int nextIndex = 0;
        while (true)
        {
            //Check if the sub string after the NewLine has enough length
            if (charPerLine < oriText.Substring(nextIndex).Length)
            {
                string sSubString = oriText.Substring(nextIndex, charPerLine);
                //Replace all keywords with the blank
                for (int i = 0; i < arrListKeyword.Count; i++)
                {
                    sSubString = sSubString.Replace(arrListKeyword[i].ToString(), "");
                }

                int numberOfLeak = charPerLine - sSubString.Length;
                int newLineIndex = nextIndex + charPerLine + numberOfLeak;//find the index to insert NewLine

                oriText = oriText.Insert(newLineIndex, Environment.NewLine);//Insert NewLine
                nextIndex = newLineIndex + Environment.NewLine.Length;//Environment.NewLine cost 2 in length

            }
            else
            {
                break;
            }
        }

        textBox1.Text = oriText;
0 голосов
/ 23 ноября 2011

Хотя, возможно, не самое чистое решение. Если вы просто рассчитываете на @ (или выполняете регулярные выражения для определения закономерностей) и добавляете это число к x (30), например:

            int paramCount = test.Where(c => c == '@').Count();

            var index = test.Select((c, i) => new { c, i })
                            .TakeWhile(q => q.i < x + paramCount)
                            .Where(q => q.c == ' ')
                            .Select(q => q.i)
                            .Last();

редактировать

Чтобы ваш счетчик учитывал только первые 30 символов (исключая '@'), вы можете выполнить агрегирование заранее:

            int paramCount = test.Select((c, i) => new { c, i })
                                 .Aggregate(0, (count, s) => s.c == '@' && s.i < x + count ? count + 1 : count);
0 голосов
/ 23 ноября 2011

Вы можете попробовать код ниже.

string sTemp = textBox1.Text.Substring(0, 30);
sTemp = sTemp.Replace(" @A ", "");
sTemp = sTemp.Replace("@A ", "");
sTemp = sTemp.Replace(" @A", "");
sTemp = sTemp.Replace("@A", "");

sTemp = sTemp.Replace(" @B ", "");
sTemp = sTemp.Replace("@B ", "");
sTemp = sTemp.Replace(" @B", "");
sTemp = sTemp.Replace("@B", "");

int numberOfLeak = 30 - sTemp.Length;
var x = 30 + numberOfLeak;
if (textBox1.Text.Length > x)
{
    textBox1.Text = textBox1.Text.Insert(x, Environment.NewLine);
} 
0 голосов
/ 23 ноября 2011
textBox1.Text.Replace("@A", "").Replace("@B", "")...
...