Задание3.txt 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390
  1. DLL
  2. #include "../DllдляПрикладного/Header.h"//подключил заголовок из другого проекта
  3. BOOL WINAPI DllMain(HINSTANCE hlnstDll, DWORD dwReason, LPVOID IpReserved)
  4. {
  5. BOOL bAllWentWell = TRUE;
  6. switch (dwReason)
  7. {
  8. case DLL_PROCESS_ATTACH:
  9. break;
  10. case DLL_THREAD_ATTACH:
  11. break;
  12. case DLL_THREAD_DETACH:
  13. break;
  14. case DLL_PROCESS_DETACH:
  15. break;
  16. }
  17. if (bAllWentWell)
  18. return TRUE;
  19. else
  20. return FALSE;
  21. }
  22. LPWSTR Reading(LPWSTR path)
  23. {
  24. DWORD d = 0;
  25. HINSTANCE FileHandle = CreateFile(PATH, GENERIC_READ, FILE_SHARE_WRITE | FILE_SHARE_READ, NULL, OPEN_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
  26. LPWSTR ReadString = calloc(100500, sizeof(WCHAR));
  27. ReadFile(FileHandle, ReadString, 100500 * sizeof(WCHAR), &d, NULL);
  28. CloseHandle(FileHandle);
  29. ReadString[d / 2] = '\n';
  30. ReadString[d / 2 + 1] = '\0';
  31. return ReadString;
  32. }
  33. DWORD LpwstrToDword(LPWSTR str)
  34. {
  35. DWORD dw = 0;
  36. for (size_t i = 0; i < wcslen(str); i++)
  37. {
  38. dw += (str[i] - '0');
  39. dw *= 10;
  40. }
  41. return dw / 10;
  42. }
  43. DWORD CountUsers(LPWSTR str)
  44. {
  45. DWORD count = 0;
  46. for (size_t i = 0; i < wcslen(str); i++)
  47. {
  48. if (str[i] == L'\n') count++;
  49. }
  50. return count;
  51. }
  52. __declspec(dllexport) U* CreateUserArray(LPWSTR path, LPDWORD n)
  53. {
  54. LPWSTR str = Reading(path);
  55. DWORD count = CountUsers(str);
  56. U* users = calloc(count, sizeof(U));
  57. DWORD poz = 0, zap = 0, ind = 0;
  58. LPWSTR strvozr = calloc(3, sizeof(TCHAR));
  59. for (size_t i = 1; i < wcslen(str); i++)
  60. {
  61. if (str[i] == '\n')
  62. {
  63. strvozr = calloc(3, sizeof(TCHAR));
  64. zap++;
  65. poz = 0;
  66. ind = 0;
  67. }
  68. else
  69. {
  70. if (str[i] == ';')
  71. {
  72. poz++;
  73. ind = 0;
  74. }
  75. else
  76. {
  77. if (poz == 0)
  78. users[zap].f[ind] = str[i];
  79. if (poz == 1)
  80. users[zap].i[ind] = str[i];
  81. if (poz == 2)
  82. users[zap].o[ind] = str[i];
  83. if (poz == 3)
  84. users[zap].g[ind] = str[i];
  85. if (poz == 4)
  86. {
  87. if (str[i] == '\r')
  88. {
  89. strvozr[ind] = '\0';
  90. users[zap].vozr = LpwstrToDword(strvozr);
  91. free(strvozr);
  92. }
  93. else strvozr[ind] = str[i];
  94. }
  95. ind++;
  96. }
  97. }
  98. }
  99. *n = count;
  100. return users;
  101. }
  102. __declspec(dllexport) U1* Ubel(U* users, LPDWORD count)
  103. {
  104. DWORD indUser = 0, con = 0, f = 0;
  105. for (DWORD i = 0; i < *count; i++)
  106. {
  107. if (users[i].vozr%5==0)
  108. {
  109. con++;
  110. }
  111. }
  112. con++;
  113. U1* Ubel = calloc(con, sizeof(U1));
  114. Ubel[0].f[0] = (WCHAR)65279;
  115. indUser++;
  116. for (DWORD i = 0; i < *count; i++)
  117. {
  118. if (users[i].vozr % 5 == 0)
  119. {
  120. for (DWORD j = 0; j < wcslen(users[i].o); j++)
  121. {
  122. Ubel[indUser].f[j] = users[i].f[j];
  123. }
  124. for (DWORD j = 0; j < wcslen(users[i].i); j++)
  125. {
  126. Ubel[indUser].i[j] = users[i].i[j];
  127. }
  128. for (DWORD j = 0; j < wcslen(users[i].o); j++)
  129. {
  130. Ubel[indUser].o[j] = users[i].o[j];
  131. }
  132. Ubel[indUser].vozr = users[i].vozr;
  133. indUser++;
  134. }
  135. }
  136. *count = con;
  137. return Ubel;
  138. }
  139. __declspec(dllexport) float Age(U* users, LPDWORD count)
  140. {
  141. float avg = 0;
  142. for (DWORD i = 1; i < *count; i++)
  143. {
  144. avg += users[i].vozr;
  145. }
  146. avg = avg / (*count - 1);
  147. return avg;
  148. }
  149. __declspec(dllexport) LPWSTR Dlina(U* users, LPDWORD count)
  150. {
  151. DWORD ind = 0, indUser = 0, f = 0;
  152. DWORD max = 0;
  153. for (DWORD i = 0; i < *count; i++)
  154. {
  155. size_t l1 = strlen(users[i].f);
  156. size_t l2 = strlen(users[i].i);
  157. size_t l3 = strlen(users[i].o);
  158. if (l1 + l2 + l3 > max)
  159. {
  160. max = l1 + l2 + l3;
  161. ind = i;
  162. }
  163. }
  164. char third[512];
  165. swprintf(third, sizeof(third), L"%s%s%s", users[ind].f, users[ind].i, users[ind].o);
  166. return third;
  167. }
  168. __declspec(dllexport) DWORD kolvo(U* users, LPDWORD count)
  169. {
  170. DWORD ind = 0, indUser = 0, con = 0, f = 0;
  171. WCHAR str = L'м';
  172. for (DWORD i = 0; i < *count; i++)
  173. {
  174. if (users[i].g[0] == str) con++;
  175. }
  176. *count = con;
  177. return con;
  178. }
  179. }
  180. Main
  181. #include "header.h"
  182. #include "header1.h"
  183. #include <strsafe.h>
  184. #define PATHDLL L"DLL.dll"
  185. #define PATHLIST L"Users.csv"
  186. typedef U1* (_cdecl* MyFunction)(LPWSTR, LPDWORD);
  187. typedef U* (_cdecl* MyFunction1)(U*, LPDWORD);
  188. typedef float(_cdecl* MyFunction2) (U*, LPDWORD);
  189. typedef LPWSTR(_cdecl* MyFunction3) (U*, LPDWORD);
  190. typedef DWORD(_cdecl* MyFunction4) (U*, LPDWORD);
  191. int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nShowCmd)
  192. {
  193. //Задание 1
  194. HINSTANCE MyDLL;
  195. if (!(MyDLL = LoadLibrary(PATHDLL))) return 1;
  196. MyFunction UserList = (MyFunction)GetProcAddress(MyDLL, "CreateUserArray");
  197. MyFunction1 UserList1 = (MyFunction1)GetProcAddress(MyDLL, "Ubel");
  198. MyFunction2 AvgUserList = (MyFunction2)GetProcAddress(MyDLL, "Age");
  199. MyFunction3 MaxFIOUser = (MyFunction3)GetProcAddress(MyDLL, "Dlina");
  200. MyFunction4 KolvoM = (MyFunction4)GetProcAddress(MyDLL, "kolvo");
  201. DWORD count = 0;
  202. U* users = UserList(PATH, &count);
  203. DWORD w;
  204. HINSTANCE FileHandle = CreateFile(L"1.csv", GENERIC_WRITE, FILE_SHARE_WRITE | FILE_SHARE_READ, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
  205. TCHAR otvFile[512];
  206. TCHAR BuferObmena[512];
  207. for (size_t i = 0; i < count-1; i++)
  208. {
  209. users[i].f[wcslen(users[i].f)] = (WCHAR)';';
  210. WriteFile(FileHandle, users[i].f, wcslen(users[i].f) * sizeof(WCHAR), &w, NULL);
  211. users[i].i[wcslen(users[i].i)] = (WCHAR)';';
  212. WriteFile(FileHandle, users[i].i, wcslen(users[i].i) * sizeof(WCHAR), &w, NULL);
  213. users[i].o[wcslen(users[i].o)] = (WCHAR)';';
  214. WriteFile(FileHandle, users[i].o, wcslen(users[i].o) * sizeof(WCHAR), &w, NULL);
  215. users[i].g[wcslen(users[i].g)] = (WCHAR)';';
  216. WriteFile(FileHandle, users[i].g, wcslen(users[i].g) * sizeof(WCHAR), &w, NULL);
  217. swprintf(otvFile, 512, TEXT("%d\r\n"), users[i].vozr);
  218. // swprintf(BuferObmena, 512, TEXT("%s;%s;%s;$s\0"), users[i].vozr);
  219. DWORD len = 0;
  220. while (otvFile[len] != '\0')
  221. {
  222. len++;
  223. }
  224. DWORD dz = 0;
  225. WriteFile(FileHandle,
  226. otvFile,
  227. len * (sizeof(char) * 2),
  228. &dz,
  229. NULL
  230. );
  231. }
  232. CloseHandle(FileHandle);
  233. //Задание 2
  234. DWORD w1;
  235. TCHAR otvFile2[512];
  236. DWORD count2 = count;
  237. U1* ubel = UserList1(users, &count2);
  238. HINSTANCE FileHandle2 = CreateFile(L"2.txt", GENERIC_WRITE, FILE_SHARE_WRITE | FILE_SHARE_READ, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
  239. for (size_t i = 1; i < count2-1; i++)
  240. {
  241. ubel[i].f[wcslen(ubel[i].f)] = (WCHAR)' ';
  242. WriteFile(FileHandle2, ubel[i].f, wcslen(ubel[i].f) * sizeof(WCHAR), &w1, NULL);
  243. ubel[i].i[wcslen(ubel[i].i)] = (WCHAR)' ';
  244. WriteFile(FileHandle2, ubel[i].i, wcslen(ubel[i].i) * sizeof(WCHAR), &w1, NULL);
  245. ubel[i].o[wcslen(ubel[i].o)] = (WCHAR)' ';
  246. WriteFile(FileHandle2, ubel[i].o, wcslen(ubel[i].o) * sizeof(WCHAR), &w1, NULL);
  247. swprintf(otvFile2, 512, TEXT("%d\r\n"), ubel[i].vozr);
  248. DWORD len = 0;
  249. while (otvFile2[len] != '\0')
  250. {
  251. len++;
  252. }
  253. DWORD dz = 0;
  254. WriteFile(FileHandle2,
  255. otvFile2,
  256. len * (sizeof(char) * 2),
  257. &dz,
  258. NULL
  259. );
  260. }
  261. CloseHandle(FileHandle2);
  262. //Задание 3 Средний возраст
  263. HKEY hKey = NULL;
  264. if (RegOpenKey(HKEY_CURRENT_USER, NULL, &hKey) != ERROR_SUCCESS)
  265. return 1;
  266. DWORD avg = AvgUserList(users, &count);
  267. /*avg = (avg + AvgUserList(users, &count)) / 2;*/
  268. if (RegSetValueEx(hKey, TEXT("ParamSize"), 0, REG_DWORD, (const BYTE*)&avg, sizeof(avg)) == ERROR_SUCCESS)
  269. {
  270. MessageBox(NULL, L"Ключ успешно создан", L"MyKey", MB_OK | MB_ICONINFORMATION);
  271. }
  272. DWORD DataType = 0;
  273. DWORD DataLen = 100500;
  274. DWORD SIZEE;
  275. TCHAR sZ[100];
  276. if (RegGetValueW(HKEY_CURRENT_USER, NULL, L"ParamSIze", RRF_RT_DWORD, &DataType, &SIZEE, &DataLen) == ERROR_SUCCESS)
  277. {
  278. StringCbPrintf(sZ, 100, TEXT("%d"), SIZEE);
  279. MessageBox(NULL, sZ, L"Средний возраст", MB_OK | MB_ICONINFORMATION);
  280. }
  281. else
  282. {
  283. MessageBox(NULL, L"Что-то пошло не так", L"Информация", MB_OK);
  284. }
  285. RegCloseKey(hKey);
  286. //Задание 3 Сама длинная ФИО
  287. HKEY hKey2 = NULL;
  288. if (RegOpenKey(HKEY_CURRENT_USER, NULL, &hKey2) != ERROR_SUCCESS)
  289. return 1;
  290. if (RegSetValueW(hKey2, L"Mykey", REG_SZ, L"Значение по умолчанию", 22 * sizeof(WCHAR)) == ERROR_SUCCESS)
  291. {
  292. MessageBox(NULL, L"Ключ успешно создан", L"Информация", MB_OK);
  293. }
  294. LPWSTR maxst = MaxFIOUser(users, &count);
  295. TCHAR buff2[512];
  296. wsprintf(buff2, L"%s", maxst);
  297. if (RegSetValueExW(hKey2, L"Mykeys", NULL, REG_SZ, &buff2, 22 * sizeof(WCHAR)) == ERROR_SUCCESS)
  298. {
  299. MessageBox(NULL, &buff2, L"ФИО", MB_OK | MB_ICONINFORMATION);
  300. }
  301. else
  302. {
  303. MessageBox(NULL, L"Что-то пошло не так", L"Информация", MB_OK);
  304. }
  305. RegCloseKey(hKey2);
  306. //Задание 3 Количество мужчин
  307. HKEY hKey3 = NULL;
  308. if (RegOpenKey(HKEY_CURRENT_USER, NULL, &hKey3) != ERROR_SUCCESS)
  309. return 1;
  310. DWORD kol = KolvoM(users, &count);
  311. if (RegSetValueEx(hKey3, TEXT("ParamSize3"), 0, REG_DWORD, (const BYTE*)&kol, sizeof(kol)) == ERROR_SUCCESS)
  312. {
  313. MessageBox(NULL, L"Ключ успешно создан", L"MyKey3", MB_OK | MB_ICONINFORMATION);
  314. }
  315. DWORD DataType2 = 0;
  316. DWORD DataLen2 = 100500;
  317. DWORD SIZEE2;
  318. TCHAR sZ2[100];
  319. if (RegGetValueW(HKEY_CURRENT_USER, NULL, L"ParamSIze3", RRF_RT_DWORD, &DataType2, &SIZEE2, &DataLen2) == ERROR_SUCCESS)
  320. {
  321. StringCbPrintf(sZ2, 100, TEXT("%d"), SIZEE2);
  322. MessageBox(NULL, sZ2, L"Количесво мужчин", MB_OK | MB_ICONINFORMATION);
  323. }
  324. else
  325. {
  326. MessageBox(NULL, L"Что-то пошло не так", L"Информация", MB_OK);
  327. }
  328. ClipboardInputText(otvFile);
  329. RegCloseKey(hKey3);
  330. }
  331. Заголовков 1
  332. #pragma once
  333. #define _CRT_SECURE_NO_WARNINGS
  334. #include <Windows.h>
  335. #include <stdio.h>
  336. #define PATH L"Users.csv"
  337. struct User
  338. {
  339. WCHAR f[30];
  340. WCHAR i[30];
  341. WCHAR o[30];
  342. WCHAR g[5];
  343. DWORD vozr;
  344. };
  345. typedef struct User U;
  346. struct Ubel
  347. {
  348. WCHAR f[30];
  349. WCHAR i[30];
  350. WCHAR o[30];
  351. WCHAR g[5];
  352. DWORD vozr;
  353. };
  354. typedef struct Ubel U1;
  355. Заголовков 2
  356. #pragma once
  357. #define _CRT_SECURE_NO_WARNINGS
  358. #include <Windows.h>
  359. #include <stdio.h>
  360. int ClipboardInputText(LPWSTR buffer)//записать строку в системный буфер
  361. {
  362. DWORD len;
  363. HANDLE hMenu;
  364. len = wcslen(buffer) + 1;
  365. hMenu = GlobalAlloc(GMEM_MOVEABLE, len * sizeof(LPWSTR));
  366. memcpy(GlobalLock(hMenu), buffer, len * sizeof(LPWSTR));
  367. GlobalUnlock(hMenu);
  368. OpenClipboard(0);
  369. EmptyClipboard();
  370. SetClipboardData(CF_UNICODETEXT, hMenu);
  371. CloseClipboard();
  372. return 0;
  373. }