主頁 > 軟體設計 > 如何使用data.table函式將代碼功能調整為規范

如何使用data.table函式將代碼功能調整為規范

2022-04-22 10:39:59 軟體設計

我想改變生成Output. 是否可以在下面的這種情況下使用該data.table功能?如果是的話,你能幫我調整一下嗎?我在下面插入了一個已完成計算的示例。下面的代碼來自一個已經解決的問題:如何調整輸出表生成的規范

library(dplyr)
library(tidyverse)
library(lubridate)


df1 <- structure(list(date1 = c("2021-06-28"), 
                      date2 = c("2021-06-30"), 
                      Category = c("FDE"), 
                      Week = c("Wednesday"), 
                      DR1 = c(4), DRM001 = c(4), DRM002 = c(2), 
                      DRM003 = c(9), DRM004 = c(5), DRM005 = c(5), 
                      DRM006 = c(2),DRM007 = c(1),
                      coef = c(8)), class = "data.frame", row.names = c(NA, -1L))


Output<-df1 %>% 
  mutate(across(starts_with("DR"), ~ coef - .),
         across(contains("date"), ymd),
         datedif = parse_number(as.character(date2-date1))
  ) %>% 
  rename_with(~str_replace(.,'(?<=[A-Z])0 (?=.)', ""),starts_with('DR')) %>% 
  rowwise %>%
  mutate(Result = if (str_c('DRM', datedif) %in% names(.)) get(str_c('DRM', datedif)) else coef) %>%
  ungroup() %>% 
  select(coef, Result)%>%data.frame()

> Output
  coef Result
1    8      6

例如:見 thatcoef是 8 和 之間的差date1date22,所以Result等于coef - DRM2如果日期之間的差異是 3 那么它將是Result = coef - DRM3

   date1      date2     Category  Week     DR1 DRM1 DRM2 DRM3 DRM4 DRM5 DRM6 DRM7 coef datedif
1 2021-06-28 2021-06-30  FDE    Wednesday   4    4    6   -1    3    3    6    7    8       2

查看:

  df1<-structure(list(Id = 8, date1 = structure(19090L, class = c("IDate", 
"Date")), date2 = structure(19090L, class = c("IDate", 
"Date")), Week = "Sexta-feira", DT = "0", Category = "PUBBAR", 
    GR = 1, DR1 = 14, DayM = 1, DayM1 = 1, DayM2 = 0, 
    DayM3 = 0, DayM4 = 1, DayM5 = 1, DayM6 = 1, DayM7 = 2, DayM8 = 2, 
    DayM9 = 2, DayM10 = 2, DayM11 = 4, DayM12 = 4, DayM13 = 4, 
    DayM14 = 4, DayM15 = 4, DayM16 = 4, DayM17 = 4, DayM18 = 4, 
    DayM19 = 4, DayM20 = 6, DayM21 = 6, DayM22 = 8, DayM23 = 8, 
    DayM24 = 8, DayM25 = 8, DayM26 = 8, DayM27 = 8, DayM28 = 8, 
    DayM29 = 8, DayM30 = 8, DayM31 = 10, DayM32 = 10, DayM33 = 10, 
    DayM34 = 10, DayM35 = 10, DayM36 = 10, DayM37 = 9, DayM38 = 9, 
    DayM39 = 9, DayM40 = 9, DayM41 = 9, DayM42 = 9, DayM43 = 9, 
    DayM44 = 9, DayM45 = 9, DayM46 = 9, DayM47 = 9, DayM48 = 9, 
    DayM49 = 9, DayM50 = 10, DayM51 = 10, DayM52 = 10, DayM53 = 10, 
    DayM54 = 10, DayM55 = 10, DayM56 = 10, DayM57 = 10, DayM58 = 10, 
    DayM59 = 10, DayM60 = 10, DayM61 = 10, DayM62 = 10, DayM63 = 10, 
    DayM64 = 10, DayM65 = 10, DayM66 = 10, DayM67 = 10, DayM68 = 10, 
    DayM69 = 10, DayM70 = 10, DayM71 = 10, DayM72 = 10, DayM73 = 10, 
    DayM74 = 10, DayM75 = 10, DayM76 = 10, DayM77 = 10, DayM78 = 10, 
    DayM79 = 10, DayM80 = 10, DayM81 = 10, DayM82 = 10, DayM83 = 10, 
    DayM84 = 10, DayM85 = 10, DayM86 = 10, DayM87 = 10, DayM88 = 10, 
    DayM89 = 10, DayM90 = 10, DayM91 = 10, DayM92 = 10, DayM93 = 10, 
    DayM94 = 10, DayM95 = 10, DayM96 = 10, DayM97 = 10, DayM98 = 10, 
    DayM99 = 10, DayM100 = 10, DayM101 = 10, DayM102 = 10, DayM103 = 10, 
    DayM104 = 10, DayM105 = 10, DayM106 = 10, DayM107 = 10, DayM108 = 10, 
    DayM109 = 10, DayM110 = 10, DayM111 = 10, DayM112 = 10, DayM113 = 10, 
    DayM114 = 10, DayM115 = 10, DayM116 = 10, DayM117 = 10, DayM118 = 10, 
    DayM119 = 10, DayM120 = 10, DayM121 = 10, DayM122 = 10, DayM123 = 10, 
    DayM124 = 10, DayM125 = 10, DayM126 = 10, DayM127 = 10, DayM128 = 10, 
    DayM129 = 10, DayM130 = 10, DayM131 = 12, DayM132 = 12, DayM133 = 12, 
    DayM134 = 12, DayM135 = 12, DayM136 = 12, DayM137 = 12, DayM138 = 12, 
    DayM139 = 12, DayM140 = 12, DayM141 = 12, DayM142 = 12, DayM143 = 12, 
    DayM144 = 12, DayM145 = 13, DayM146 = 13, DayM147 = 13, DayM148 = 13, 
    DayM149 = 13, DayM150 = 13, DayM151 = 13, DayM152 = 13, DayM153 = 14, 
    DayM154 = 14, DayM155 = 14, DayM156 = 14, DayM157 = 14, DayM158 = 14, 
    DayM159 = 14, DayM160 = 14, DayM161 = 14, DayM162 = 14, DayM163 = 14, 
    DayM164 = 14, DayM165 = 14, DayM166 = 14, DayM167 = 14, DayM168 = 14, 
    DayM169 = 14, DayM170 = 14, DayM171 = 14, DayM172 = 14, DayM173 = 14, 
    DayM174 = 14, DayM175 = 14, DayM176 = 14, DayM177 = 14, DayM178 = 14, 
    DayM179 = 14, DayM180 = 14, DayM181 = 14, DayM182 = 14, DayM183 = 14, 
    DayM184 = 14, DayM185 = 14, DayM186 = 14, DayM187 = 14, DayM188 = 14, 
    DayM189 = 14, DayM190 = 14, DayM191 = 14, DayM192 = 14, DayM193 = 14, 
    DayM194 = 14, DayM195 = 14, DayM196 = 14, DayM197 = 14, DayM198 = 14, 
    DayM199 = 14, DayM200 = 14, DayM201 = 14, DayM202 = 14, DayM203 = 14, 
    DayM204 = 14, DayM205 = 14, DayM206 = 14, DayM207 = 14, DayM208 = 14, 
    DayM209 = 14, DayM210 = 14, DayM211 = 14, DayM212 = 14, DayM213 = 14, 
    DayM214 = 14, DayM215 = 14, DayM216 = 14, DayM217 = 14, DayM218 = 14, 
    DayM219 = 14, DayM220 = 14, DayM221 = 14, DayM222 = 14, DayM223 = 14, 
    DayM224 = 14, DayM225 = 14, DayM226 = 14, DayM227 = 14, DayM228 = 14, 
    DayM229 = 14, DayM230 = 14, DayM231 = 14, DayM232 = 14, DayM233 = 14, 
    DayM234 = 14, DayM235 = 14, DayM236 = 14, DayM237 = 14, DayM238 = 14, 
    DayM239 = 14, DayM240 = 14, DayM241 = 14, DayM242 = 14, DayM243 = 14, 
    DayM244 = 14, DayM245 = 14, DayM246 = 14, DayM247 = 14, DayM248 = 14, 
    DayM249 = 14, DayM250 = 14, DayM251 = 14, DayM252 = 14, DayM253 = 14, 
    DayM254 = 14, DayM255 = 14, DayM256 = 14, DayM257 = 14, DayM258 = 14, 
    DayM259 = 14, DayM260 = 14, DayM261 = 14, DayM262 = 14, DayM263 = 14, 
    DayM264 = 14, DayM265 = 14, DayM266 = 14, DayM267 = 14, DayM268 = 14, 
    DayM269 = 14, DayM270 = 14, DayM271 = 14, DayM272 = 14, DayM273 = 14, 
    DayM274 = 14, DayM275 = 14, DayM276 = 14, DayM277 = 14, DayM278 = 14, 
    DayM279 = 14, DayM280 = 14, DayM281 = 14, DayM282 = 14, DayM283 = 14, 
    DayM284 = 14, DayM285 = 14, DayM286 = 14, DayM287 = 14, DayM288 = 14, 
    DayM289 = 14, DayM290 = 14, DayM291 = 14, DayM292 = 14, DayM293 = 14, 
    DayM294 = 14, DayM295 = 14, DayM296 = 14, DayM297 = 14, DayM298 = 14, 
    DayM299 = 14, DayM300 = 14, DayM301 = 14, DayM302 = 14, DayM303 = 14, 
    DayM304 = 14, DayM305 = 14, DayM306 = 14, DayM307 = 14, DayM308 = 14, 
    DayM309 = 14, DayM310 = 14, DayM311 = 14, DayM312 = 14, DayM313 = 14, 
    DayM314 = 14, DayM315 = 14, DayM316 = 14, DayM317 = 14, DayM318 = 14, 
    DayM319 = 14, DayM320 = 14, DayM321 = 14, DayM322 = 14, DayM323 = 14, 
    DayM324 = 14, DayM325 = 14, DayM326 = 14, DayM327 = 14, DayM328 = 14, 
    DayM329 = 14, DayM330 = 14, DayM331 = 14, DayM332 = 14, DayM333 = 14, 
    DayM334 = 14, DayM335 = 14, DayM336 = 14, DayM337 = 14, DayM338 = 14, 
    DayM339 = 14, DayM340 = 14, DayM341 = 14, DayM342 = 14, DayM343 = 14, 
    DayM344 = 14, DayM345 = 14, DayM346 = 14, DayM347 = 14, DayM348 = 14, 
    DayM349 = 14, DayM350 = 14, DayM351 = 14, DayM352 = 14, DayM353 = 14, 
    DayM354 = 14, DayM355 = 14, DayM356 = 14, DayM357 = 14, DayM358 = 14, 
    DayM359 = 14, DayM360 = 14, DayM361 = 14, DayM362 = 14, DayM363 = 14, 
    DayM364 = 14, DayM365 = 14, coef = 14, datedif = 0L), class = "data.frame", row.names = c(NA, 
-1L))

df1<-as.data.table(df1)

Output2 <-  df1[,  .(coef, Result = fcoalesce(as.matrix(.SD)[cbind(.I,         match(paste0('DayM', datedif), names(.SD)))], coef)),       .SDcols = patterns("^DayM\\d ")]

> Output2
   coef Result
1:   14     14

結果是coef - DayM= 14 - 1 = 13

不使用data.table

    df1<-structure(list(Id = 8, date1 = structure(1649376000, tzone = "UTC", class = c("POSIXct", 
    "POSIXt")), date2 = structure(1649376000, tzone = "UTC", class = c("POSIXct", 
    "POSIXt")), Week = "Sexta-feira", DT = "0", Category = "PUBBAR", 
        GR = 1, DayR1 = 0, DayM000 = 13, DayM001 = 13, 
        DayM002 = 14, DayM003 = 14, DayM004 = 13, DayM005 = 13, DayM006 = 13, 
        DayM007 = 12, DayM008 = 12, DayM009 = 12, DayM010 = 12, DayM011 = 10, 
        DayM012 = 10, DayM013 = 10, DayM014 = 10, DayM015 = 10, DayM016 = 10, 
        DayM017 = 10, DayM018 = 10, DayM019 = 10, DayM020 = 8, DayM021 = 8, 
        DayM022 = 6, DayM023 = 6, DayM024 = 6, DayM025 = 6, DayM026 = 6, 
        DayM027 = 6, DayM028 = 6, DayM029 = 6, DayM030 = 6, DayM031 = 4, 
        DayM032 = 4, DayM033 = 4, DayM034 = 4, DayM035 = 4, DayM036 = 4, 
        DayM037 = 5, DayM038 = 5, DayM039 = 5, DayM040 = 5, DayM041 = 5, 
        DayM042 = 5, DayM043 = 5, DayM044 = 5, DayM045 = 5, DayM046 = 5, 
        DayM047 = 5, DayM048 = 5, DayM049 = 5, DayM050 = 4, DayM051 = 4, 
        DayM052 = 4, DayM053 = 4, DayM054 = 4, DayM055 = 4, DayM056 = 4, 
        DayM057 = 4, DayM058 = 4, DayM059 = 4, DayM060 = 4, DayM061 = 4, 
        DayM062 = 4, DayM063 = 4, DayM064 = 4, DayM065 = 4, DayM066 = 4, 
        DayM067 = 4, DayM068 = 4, DayM069 = 4, DayM070 = 4, DayM071 = 4, 
        DayM072 = 4, DayM073 = 4, DayM074 = 4, DayM075 = 4, DayM076 = 4, 
        DayM077 = 4, DayM078 = 4, DayM079 = 4, DayM080 = 4, DayM081 = 4, 
        DayM082 = 4, DayM083 = 4, DayM084 = 4, DayM085 = 4, DayM086 = 4, 
        DayM087 = 4, DayM088 = 4, DayM089 = 4, DayM090 = 4, DayM091 = 4, 
        DayM092 = 4, DayM093 = 4, DayM094 = 4, DayM095 = 4, DayM096 = 4, 
        DayM097 = 4, DayM098 = 4, DayM099 = 4, DayM100 = 4, DayM101 = 4, 
        DayM102 = 4, DayM103 = 4, DayM104 = 4, DayM105 = 4, DayM106 = 4, 
        DayM107 = 4, DayM108 = 4, DayM109 = 4, DayM110 = 4, DayM111 = 4, 
        DayM112 = 4, DayM113 = 4, DayM114 = 4, DayM115 = 4, DayM116 = 4, 
        DayM117 = 4, DayM118 = 4, DayM119 = 4, DayM120 = 4, DayM121 = 4, 
        DayM122 = 4, DayM123 = 4, DayM124 = 4, DayM125 = 4, DayM126 = 4, 
        DayM127 = 4, DayM128 = 4, DayM129 = 4, DayM130 = 4, DayM131 = 2, 
        DayM132 = 2, DayM133 = 2, DayM134 = 2, DayM135 = 2, DayM136 = 2, 
        DayM137 = 2, DayM138 = 2, DayM139 = 2, DayM140 = 2, DayM141 = 2, 
        DayM142 = 2, DayM143 = 2, DayM144 = 2, DayM145 = 1, DayM146 = 1, 
        DayM147 = 1, DayM148 = 1, DayM149 = 1, DayM150 = 1, DayM151 = 1, 
        DayM152 = 1, DayM153 = 0, DayM154 = 0, DayM155 = 0, DayM156 = 0, 
        DayM157 = 0, DayM158 = 0, DayM159 = 0, DayM160 = 0, DayM161 = 0, 
        DayM162 = 0, DayM163 = 0, DayM164 = 0, DayM165 = 0, DayM166 = 0, 
        DayM167 = 0, DayM168 = 0, DayM169 = 0, DayM170 = 0, DayM171 = 0, 
        DayM172 = 0, DayM173 = 0, DayM174 = 0, DayM175 = 0, DayM176 = 0, 
        DayM177 = 0, DayM178 = 0, DayM179 = 0, DayM180 = 0, DayM181 = 0, 
        DayM182 = 0, DayM183 = 0, DayM184 = 0, DayM185 = 0, DayM186 = 0, 
        DayM187 = 0, DayM188 = 0, DayM189 = 0, DayM190 = 0, DayM191 = 0, 
        DayM192 = 0, DayM193 = 0, DayM194 = 0, DayM195 = 0, DayM196 = 0, 
        DayM197 = 0, DayM198 = 0, DayM199 = 0, DayM200 = 0, DayM201 = 0, 
        DayM202 = 0, DayM203 = 0, DayM204 = 0, DayM205 = 0, DayM206 = 0, 
        DayM207 = 0, DayM208 = 0, DayM209 = 0, DayM210 = 0, DayM211 = 0, 
        DayM212 = 0, DayM213 = 0, DayM214 = 0, DayM215 = 0, DayM216 = 0, 
        DayM217 = 0, DayM218 = 0, DayM219 = 0, DayM220 = 0, DayM221 = 0, 
        DayM222 = 0, DayM223 = 0, DayM224 = 0, DayM225 = 0, DayM226 = 0, 
        DayM227 = 0, DayM228 = 0, DayM229 = 0, DayM230 = 0, DayM231 = 0, 
        DayM232 = 0, DayM233 = 0, DayM234 = 0, DayM235 = 0, DayM236 = 0, 
        DayM237 = 0, DayM238 = 0, DayM239 = 0, DayM240 = 0, DayM241 = 0, 
        DayM242 = 0, DayM243 = 0, DayM244 = 0, DayM245 = 0, DayM246 = 0, 
        DayM247 = 0, DayM248 = 0, DayM249 = 0, DayM250 = 0, DayM251 = 0, 
        DayM252 = 0, DayM253 = 0, DayM254 = 0, DayM255 = 0, DayM256 = 0, 
        DayM257 = 0, DayM258 = 0, DayM259 = 0, DayM260 = 0, DayM261 = 0, 
        DayM262 = 0, DayM263 = 0, DayM264 = 0, DayM265 = 0, DayM266 = 0, 
        DayM267 = 0, DayM268 = 0, DayM269 = 0, DayM270 = 0, DayM271 = 0, 
        DayM272 = 0, DayM273 = 0, DayM274 = 0, DayM275 = 0, DayM276 = 0, 
        DayM277 = 0, DayM278 = 0, DayM279 = 0, DayM280 = 0, DayM281 = 0, 
        DayM282 = 0, DayM283 = 0, DayM284 = 0, DayM285 = 0, DayM286 = 0, 
        DayM287 = 0, DayM288 = 0, DayM289 = 0, DayM290 = 0, DayM291 = 0, 
        DayM292 = 0, DayM293 = 0, DayM294 = 0, DayM295 = 0, DayM296 = 0, 
        DayM297 = 0, DayM298 = 0, DayM299 = 0, DayM300 = 0, DayM301 = 0, 
        DayM302 = 0, DayM303 = 0, DayM304 = 0, DayM305 = 0, DayM306 = 0, 
        DayM307 = 0, DayM308 = 0, DayM309 = 0, DayM310 = 0, DayM311 = 0, 
        DayM312 = 0, DayM313 = 0, DayM314 = 0, DayM315 = 0, DayM316 = 0, 
        DayM317 = 0, DayM318 = 0, DayM319 = 0, DayM320 = 0, DayM321 = 0, 
        DayM322 = 0, DayM323 = 0, DayM324 = 0, DayM325 = 0, DayM326 = 0, 
        DayM327 = 0, DayM328 = 0, DayM329 = 0, DayM330 = 0, DayM331 = 0, 
        DayM332 = 0, DayM333 = 0, DayM334 = 0, DayM335 = 0, DayM336 = 0, 
        DayM337 = 0, DayM338 = 0, DayM339 = 0, DayM340 = 0, DayM341 = 0, 
        DayM342 = 0, DayM343 = 0, DayM344 = 0, DayM345 = 0, DayM346 = 0, 
        DayM347 = 0, DayM348 = 0, DayM349 = 0, DayM350 = 0, DayM351 = 0, 
        DayM352 = 0, DayM353 = 0, DayM354 = 0, DayM355 = 0, DayM356 = 0, 
        DayM357 = 0, DayM358 = 0, DayM359 = 0, DayM360 = 0, DayM361 = 0, 
        DayM362 = 0, DayM363 = 0, DayM364 = 0, DayM365 = 0, coef = 14), class = "data.frame", row.names = c(NA, 
    -1L))
    
    df1%>% mutate(across(starts_with("Day"), ~coef - .),
                           across(contains("date"), ymd),
                           datedif = parse_number(as.character(date2-date1)))%>%
        rename_with(~str_replace(.,'(?<=[A-Z])0 (?=.)', ""), starts_with('Day')) %>%
        rowwise %>%
        mutate(Result= if (str_c('DayM', datedif) %in% names(.)) get(str_c('DayM', datedif)) else coef) %>%
        ungroup() %>%
select(coef, Result)%>%data.frame()

  coef Result
1   14      1

uj5u.com熱心網友回復:

使用data.table,我們可以指定.SDcols選擇“DR”列或“date_cols”并將輸出分配給那些,然后使用行/列索引來提取值以創建“結果”,而不是使用逐行匹配

library(data.table)
# get the column names that starts with DR
dr_names <- grep("^DR", names(df1), value = TRUE)
# get the columns that contains date as substring
date_names <- grep("date", names(df1), value = TRUE)
# setDT - converts the data.frame to data.table
# .SDcols - specify the dr_names, date_names, loop over those
# with lapply, apply the functions and assign (`:=`) back to 
# same columns
setDT(df1)[, (dr_names) := lapply(.SD, function(x) coef - x), .SDcols = dr_names
    ][, (date_names) := lapply(.SD, as.IDate), .SDcols = date_names
    ][, datedif := date2 - date1]
# rename with setnames
setnames(df1, dr_names, sub("([A-Z])0 ", "\\1", dr_names))

# Extract the corresponding 'DRM' column based on the value from 
# datediff and match it with the DRM column names
# using a row/column indexing 
# return the Result and coef columns 
Output2 <- df1[,  .(coef, Result = as.matrix(.SD)[cbind(.I, 
       match(paste0('DRM', datedif), names(.SD)))]), 
     .SDcols = patterns("^DRM\\d ")]
Output2[is.na(Result), Result := coef]

-輸出

> Output2
    coef Result
   <num>  <num>
1:     8      6

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/460966.html

標籤:r 数据表

上一篇:在R中,如何將日期和時間字符列組合成一列?

下一篇:在R中檢查一個陳述是否連續三年為真

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more