void Fun_Select_2() // dSSd Выбор сочетаний из массивов dSe1_Bal_D и dSe1_Bal_W с Proba>67
{
// 1. УДАЛЯЕМ старые файлы// 2. ПЕРЕБИРАЕМ в поиске соответствия// 3. ПЕЧАТАЕМ найденное в файл// 1. УДАЛЯЕМ старые файлыif(use_Print_Rep_dSS == 1) // =0 -> Условие отключено, =1 -> Печатать в log файл Промежуточные отчёты (dSS)
{
LogName="Rep_dSSd "+EN; // (Interum Report) Название ЛОГА + Название ЭТОГО ЭКСПЕРТА, передаваемое в log файл// Если файл с таким именем существует, то удаляем его ...
ld=log_delete(LogName); // ФЛАГ log файла, удаляемого в директории "logs\\" if(ld==1)
Alert ("Старый файл dSSd УДАЛЁН");
LogName="Rep_dSSw "+EN; // (Interum Report) Название ЛОГА + Название ЭТОГО ЭКСПЕРТА, передаваемое в log файл// Если файл с таким именем существует, то удаляем его ...
ld=log_delete(LogName); // ФЛАГ log файла, удаляемого в директории "logs\\" if(ld==1)
Alert ("Старый файл dSSw УДАЛЁН");
}
// 2. ПЕРЕБИРАЕМ в поиске соответствия// Находим соответствие между [1]-"Num1 А" и [4]-"Num1 B" в массивах dSe1_Bal_D и dSe1_Bal_Wint t=0; // Техническая переменнаяint d=0; // Техническая переменнаяint w=0; // Техническая переменнаяint D=0; // Техническая переменнаяint W=0; // Техническая переменнаяint S=0; // Техническая переменная// Если есть соответствие тогда записываем её в массив dSSd[][90]
Count_dSSd=0; // "Обнуляем" Счётчик записей (строк) в массиве dSSd[][90]
Range_dSSd_one=0; // "Обнуляем" Размер первого измерения (число строк) с индексом_измерения=[0] массива dSSd[][90];
Range_dSSd_two=0; // "Обнуляем" Размер второго измерения (число столбцов) с индексом_измерения=[1] массива dSSd[][90];for(d=0, t=0; d<Range_dSe1_Bal_D_one; d++)
{
for(w=0; w<Range_dSe1_Bal_W_one; w++)
{
if( (dSe1_Bal_W[w][1]==dSe1_Bal_D[d][1]) && (dSe1_Bal_W[w][4]==dSe1_Bal_D[d][4]) )
{
Count_dSSd++; // Счётчик записей (строк) в массиве dSSd[][90]ArrayResize(dSSd, Count_dSSd, 200000); // Задайм новый размер массива с резервированием памяти на 100000 записей (строк) for(S=0, D=0; D<45; D++, S++)
dSSd[t][S] = dSe1_Bal_D[d][D]; // Значения строки массива dSe1_Bal_Dfor(S=45, W=0; W<45; W++, S++)
dSSd[t][S] = dSe1_Bal_W[w][W]; // Значения строки массива dSe1_Bal_W
t++; // Увеличили индекс массива dSSd на "1"
}
}
}
Range_dSSd_one = ArrayRange(dSSd, 0); // Размер первого измерения (число строк) с индексом_измерения=[0] массива dSSd[][90];
Range_dSSd_two = ArrayRange(dSSd, 1); // Размер второго измерения (число столбцов) с индексом_измерения=[1] массива dSSd[][90];// Если есть соответствие тогда записываем её в массив dSSw[][90]
Count_dSSw=0; // "Обнуляем" Счётчик записей (строк) в массиве dSSw[][90]
Range_dSSw_one=0; // "Обнуляем" Размер первого измерения (число строк) с индексом_измерения=[0] массива dSSw[][90];
Range_dSSw_two=0; // "Обнуляем" Размер второго измерения (число столбцов) с индексом_измерения=[1] массива dSSw[][90];for(d=0, t=0; d<Range_dSe1_Bal_D_one; d++)
{
for(w=0; w<Range_dSe1_Bal_W_one; w++)
{
if( (dSe1_Bal_W[w][1]==dSe1_Bal_D[d][1]) && (dSe1_Bal_W[w][4]==dSe1_Bal_D[d][4]) )
{
Count_dSSw++; // Счётчик записей (строк) в массиве dSSw[][90]ArrayResize(dSSw, Count_dSSw, 200000); // Задайм новый размер массива с резервированием памяти на 100000 записей (строк) for(S=0, W=0; W<45; W++, S++)
dSSw[t][S] = dSe1_Bal_W[w][W]; // Значения строки массива dSe1_Bal_Wfor(S=45, D=0; D<45; D++, S++)
dSSw[t][S] = dSe1_Bal_D[d][D]; // Значения строки массива dSe1_Bal_D
t++; // Увеличили индекс массива dSSw на "1"
}
}
}
Range_dSSw_one = ArrayRange(dSSw, 0); // Размер первого измерения (число строк) с индексом_измерения=[0] массива dSSw[][90];
Range_dSSw_two = ArrayRange(dSSw, 1); // Размер второго измерения (число столбцов) с индексом_измерения=[1] массива dSSw[][90];// 3. ПЕЧАТАЕМ найденное в файлint LH_Rep=0; // Хэндл log файла, открытого в директории "logs\\" if(use_Print_Rep_dSS == 1) // =0 -> Условие отключено, =1 -> Печатать в log файл Промежуточные отчёты (dSS)
{
if(Count_dSSd>0)
{
LogName="Rep_dSSd "+EN; // (Interum Report) Название ЛОГА + Название ЭТОГО ЭКСПЕРТА, передаваемое в log файл
LH_Rep=log_open(LogName); // Хэндл log файла, открытого в директории "logs\\"
Fun_Rep_mass90(LH_Rep, dSSd, Count_dSSd); // Функция F 135 Запись Массива mass90[][90] в Промежуточный отчёт в *.csv файл
log_close(LH_Rep); // Закрываем лог-файл этого экспертаAlert ("Записан ОТЧЁТ ", LogName);
}
if(Count_dSSw>0)
{
LogName="Rep_dSSw "+EN; // (Interum Report) Название ЛОГА + Название ЭТОГО ЭКСПЕРТА, передаваемое в log файл
LH_Rep=log_open(LogName); // Хэндл log файла, открытого в директории "logs\\"
Fun_Rep_mass90(LH_Rep, dSSw, Count_dSSw); // Функция F 135 Запись Массива mass90[][90] в Промежуточный отчёт в *.csv файл
log_close(LH_Rep); // Закрываем лог-файл этого экспертаAlert ("Записан ОТЧЁТ ", LogName);
}
}
}
你能告诉我为什么会出现这种情况吗?:
Fun_1()和Fun_2()是相似的。
你能告诉我什么会导致这种情况吗?:
Fun_1()和Fun_2()是相似的。
在学术上--这些函数并不纯粹,而且改变了全局状态。
简而言之--这两个函数都是读和写一个全局变量 或文件。
在学术上--这些函数并不纯粹,而且改变了全局状态。
简而言之--这两个函数都是读和写一个全局变量 或文件。
是的,他们每个人都写了一个文件。那么?
并且不在一起工作 :-)
PS.在没有消息来源的情况下,不可能更准确地说出地下敲诈的来源。某处有一个错误--纠正它
节省空间和提高感知力--在一个功能中。它仍然不工作。
对于未来--如果你可能需要函数结果(至少是工作/不工作),不要使其无效。粗略一看,很难确定有一个 "被触发 "的标准--它是无效的,无论你怎么扔都是好的。
对调试器的权利。
你有一堆全局变量 Count_XXX,Range_XXX,你把它们转换(加上dSSxx[]数组),用它们来决定是否记录,然后把它们传到某个地方,可以是引用,也可以是值...
他们的重新计算显然有问题--当你再次调用时,Count_dSS得到0。打印可以帮助弄清楚,或者断点和观察。
为了将来--如果你可能需要函数的结果(至少它工作了或没有),不要让它失效。一眼望去,很难确定 "被触发 "的标准是什么--它是无效的,不管你怎么扔,一切都很好。
对调试器的权利。
你有一堆全局变量 Count_XXX,Range_XXX,你将它们转换(加上数组dSSxx[]),根据它们决定是否记录,然后通过引用或值传递到某个地方......
他们的重新计算显然有问题--当你再次调用时,Count_dSS得到0。打印可以帮助弄清楚,或者断点和观察。
一个简化的版本。
//有两个动态数组 A[][2]和B[][2]。
// 我们正在寻找第一个维度索引 "0 "的匹配。
// 阵列A 阵列B
// 31 25 19 66
// 44 15 62 30
// 62 47 54 71
// 31 94
// 我们想得到的是。
// 阵列dSSd[][4] 阵列dSSw[][4]
// 31 25 31 94 31 94 31 25
// 62 47 62 30 62 30 62 47
你指的是哪种 重召?
一个简化的版本。
我指的是一个与第一个类似的函数(在细节上可能有所不同)。你问了同样的问题--为什么这些功能单独工作,但一个接一个(不管顺序如何)却不工作。更确切地说,只有第一个函数起作用并记录了一些东西。
好了--操起全局状态,也就是说,这些函数中的第一个调用改变了全局变量或数组的内容。你应该更清楚,为什么写到文件 时要改变 :-)诚实地 - 突破
例如,我就觉得很难,很不情愿。找一个调试器或在所有可疑的地方已经放上打印机。你理解命名的逻辑,并对它应该如何工作有一些想法(虽然与现实不一致 :-) )。
PS/从对输入和输出的解释中,我发现用两个数组dSSx[][4]就够了,用一个dSS[][3]就够了 :-)
我指的是一个与第一个类似的函数(在细节上可能有所不同)。你问了同样的问题--为什么这些功能分别起作用,而一个接一个(无论顺序如何)却不起作用。更确切地说,只有第一个函数起作用并记录了一些东西。
所以--全局状态被搞乱了,也就是说,这些函数中的第一个调用改变了全局变量或数组的内容。也许你更清楚为什么他们在写到文件 时要改变它 :-)。诚实地 - 突破
例如,我就觉得很难,很不情愿。找一个调试器或在所有可疑的地方已经放上打印机。你理解命名逻辑,并对它应该如何工作有一些想法(与现实不一致 :-) )。
PS/从对输入和输出的解释中,我发现用两个数组dSSx[][4]就够了,用一个dSS[][3]就够了 :-)