pyflink 滚动窗口实例

写在前头:

更多大数据相关精彩内容请进我的知识星球,每周定期更新

 正篇

技术路线:模拟kafka生产者发送数据——>flink对kafka数据实时计算处理——>处理后的数据发送到kafka

1、模拟客流数据的生产者,参考https://blog.csdn.net/qq_22611181/article/details/119900250

2、flink聚合操作原理介绍,参考https://blog.csdn.net/qq_22611181/article/details/119916825

滚动窗口示例:

以客流数据为例,20s为一个窗口,计算该事件窗口内的客流数和

kafka中数据样式为:

{'stationid':1, 'stationname':

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个 Windows 滚动条的示例代码: ```c++ #include <windows.h> LRESULT CALLBACK WndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam); int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow) { // 注册窗口类 WNDCLASS wc = {0}; wc.lpfnWndProc = WndProc; wc.hInstance = hInstance; wc.hCursor = LoadCursor(NULL, IDC_ARROW); wc.hbrBackground = (HBRUSH)(COLOR_WINDOW + 1); wc.lpszClassName = TEXT("ScrollDemo"); RegisterClass(&wc); // 创建窗口 HWND hwnd = CreateWindow(TEXT("ScrollDemo"), TEXT("Scroll Demo"), WS_OVERLAPPEDWINDOW, CW_USEDEFAULT, CW_USEDEFAULT, 400, 300, NULL, NULL, hInstance, NULL); // 显示窗口 ShowWindow(hwnd, nCmdShow); UpdateWindow(hwnd); // 消息循环 MSG msg; while (GetMessage(&msg, NULL, 0, 0)) { TranslateMessage(&msg); DispatchMessage(&msg); } return (int)msg.wParam; } LRESULT CALLBACK WndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam) { static int yPos; static SCROLLINFO si = {0}; si.cbSize = sizeof(si); si.fMask = SIF_RANGE | SIF_POS | SIF_PAGE | SIF_TRACKPOS; si.nMin = 0; si.nMax = 1000; si.nPos = 0; si.nPage = 100; switch (msg) { case WM_CREATE: SetScrollInfo(hwnd, SB_VERT, &si, TRUE); break; case WM_VSCROLL: switch (LOWORD(wParam)) { case SB_LINEUP: yPos = si.nPos - 10; break; case SB_LINEDOWN: yPos = si.nPos + 10; break; case SB_PAGEUP: yPos = si.nPos - si.nPage; break; case SB_PAGEDOWN: yPos = si.nPos + si.nPage; break; case SB_THUMBTRACK: yPos = HIWORD(wParam); break; default: break; } yPos = max(0, yPos); yPos = min(si.nMax - (int)si.nPage + 1, yPos); if (yPos != si.nPos) { si.nPos = yPos; SetScrollInfo(hwnd, SB_VERT, &si, TRUE); ScrollWindow(hwnd, 0, -(si.nPos - yPos), NULL, NULL); } break; case WM_PAINT: { PAINTSTRUCT ps; HDC hdc = BeginPaint(hwnd, &ps); RECT rc; GetClientRect(hwnd, &rc); for (int i = 0; i < 100; i++) { TCHAR buf[16]; wsprintf(buf, TEXT("%d"), i); TextOut(hdc, rc.left + 10, rc.top + i * 20 - si.nPos, buf, lstrlen(buf)); } EndPaint(hwnd, &ps); } break; case WM_DESTROY: PostQuitMessage(0); break; default: return DefWindowProc(hwnd, msg, wParam, lParam); } return 0; }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值