Sponsored Content
Full Discussion: awk with many if statements
Top Forums Shell Programming and Scripting awk with many if statements Post 302856405 by Chubler_XL on Monday 23rd of September 2013 09:00:35 PM
Old 09-23-2013
Something like this might be a bit more readable and maintainable.

Code:
awk ' BEGIN {
  A[236,199, 32]=200
  A[236, 32,199]=200
  A[236,218, 32]=200
  A[236,237, 32]=200
  A[236,227, 32]=200
  A[236,225,222]=200
  A[236,229, 32]=200
  A[236,199,199]=200
  A[236,207, 32]=200
  A[236,237,209]=200
  A[236,207, 32]=200
  A[236,237,209]=200
  A[236,195, 32]=200
  A[236,199,227]=200
  A[236,228, 32]=200
  A[236,225, 32]=200
  A[236,202, 32]=200
  A[236, 32,218]=200
  A[236, 32,225]=200
  A[236,237,199]=200
  A[236,212, 32]=200
  A[236, 32,209]=200
  A[236, 32,237]=200
  A[236,230, 32]=200
  A[236, 32,210]=200
  A[236,222,199]=200
  A[236,199,230]=200
  A[236,207,218]=200
  A[236,225,225]=200
  A[236,211, 32]=200
  A[236,220,194]=203
  A[236,209,200]=203
}
{ A[++c] = $1 }
END {
   for(i=1;i<c;i++)
      if((A[i] SUBSEP A[i+1] SUBSEP A[i+2]) in B) A[i]=B[A[i],A[i+1],A[i+2]]
}

 

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

awk compound statements

how can i use two or multiple statements in the if part of an awk code for example i want to check two flag if they are true i will write some print operations and increase the counter. here is the c version of the code that i want to write: counter=0; if (flag1==1 && flag2==0) {... (7 Replies)
Discussion started by: gfhgfnhhn
7 Replies

2. Shell Programming and Scripting

Help a newbie please with awk if else statements

Hi, Despite reading the Conditional Statements chapter in the O'Reilly Sed & Awk book several times and looking at numerous examples, I cannot for the life of me get any kind of if ... else statement to work in my awk scripts! My scripts work perfectly (as they are written at least) and do what... (4 Replies)
Discussion started by: jonathanm
4 Replies

3. Shell Programming and Scripting

Combine awk statements

I have an awk statement that works but I am calling awk twice and I know there has to be a way to combine the two statements into one. The purpose is to pull out just the ip address from loopback1. cat config.txt | nawk 'BEGIN {FS="\n"}{RS="!"}{if ( $0 ~ "interface loopback1" ) print$4}' | nawk... (5 Replies)
Discussion started by: numele
5 Replies

4. Shell Programming and Scripting

Combining awk statements

I have a pretty simple script below: #!/bin/sh for i in *.cfg do temp=`awk '/^InputDirectory=/' ${i}` input_dir=`echo ${temp} | awk '{ print substr( $0, 16) }'` echo ${input_dir} done As you can see its opening each cfg file and searching for the line that has "InputDirectory="... (3 Replies)
Discussion started by: ssbsts
3 Replies

5. Shell Programming and Scripting

Combining AWK statements

Hello UNIX Community, I have file that contains the following data: testAwk2.csv rabbit penguin goat giraffe emu ostrich hyena elephant panda dog cat pig lizard snake antelope platypus tiger cheetah lion rhino spider I then find the character length of the... (1 Reply)
Discussion started by: vnayak
1 Replies

6. UNIX for Dummies Questions & Answers

AWK w/ if statements failing.

I'm converting some code from ksh on my macbook (Version M 1993-12-28 s+) to an older solaris machine with ksh 88. I can't seem to figure out this line, it worked on the new shell version. set -A combo -- $(for x in ${ImageIDs}; do nawk -v s=$x 'if($2 == s) getline ; getline if ($1 ==... (2 Replies)
Discussion started by: nerdcurious
2 Replies

7. Shell Programming and Scripting

How to use awk or nawk by using Conditional Statements

Hi Guys! Anybody know how can I use a nawk or awk on a script and printing the NAME, SECTION (must be 410 or 411 or 414) and TOTAL COST of CLASS 1 and 3 combined must be greater than 50. See below desired output file. input.txt: NAME,CLASS,COST,SECTION JOHN,1,10,410 JOHN,2,20,410... (2 Replies)
Discussion started by: pinpe
2 Replies

8. UNIX for Dummies Questions & Answers

Combine two awk statements into one

Hi, I have the following two awk statements which I'd like to consolidate into one by piping the output from the first into the second awk statement (rather than having to write kat.txt out to a file and then reading back in). awk 'BEGIN {FS=OFS=" "} {printf("%s ", $2);for (x=7; x<=10;... (3 Replies)
Discussion started by: kasan0
3 Replies

9. Shell Programming and Scripting

awk problem - combining awk statements

i have a datafile that has several lines that look like this: 2,dataflow,Sun Mar 17 16:50:01 2013,1363539001,2990,excelsheet,660,mortar,660,4 using the following command: awk -F, '{$3=strftime("%a %b %d %T %Y,%s",$3)}1' OFS=, $DATAFILE | egrep -v "\-OLDISSUES," | ${AWK} "/${MONTH} ${DAY}... (7 Replies)
Discussion started by: SkySmart
7 Replies

10. Shell Programming and Scripting

Nested awk Statements

Hello again everyone, yes, I'm back again for more help! So I'm attempting to read two separate files and generate some XML code from that. My current code is: BEGIN { print "<?xml version=\"1.0\" encoding=\"utf-8\">" print "<Export>" } { x=1; print "<section name=\"Query" NR "\">"... (5 Replies)
Discussion started by: Parrakarry
5 Replies
iconv_8859-1(5) 					Standards, Environments, and Macros					   iconv_8859-1(5)

NAME
iconv_8859-1 - code set conversion tables for ISO 8859-1 (Latin 1) DESCRIPTION
The following code set conversions are supported: +--------------------------------------------------------------------+ | Code Set Conversions Supported | +--------------+--------+--------------+--------+--------------------+ | Code |Symbol |Target Code |Symbol | Target Output | +--------------+--------+--------------+--------+--------------------+ |ISO 8859-1 |8859 |ISO 646 |646 | 7 bit ASCII | +--------------+--------+--------------+--------+--------------------+ |ISO 8859-1 |8859 |ISO 646de |646de | German | +--------------+--------+--------------+--------+--------------------+ |ISO 8859-1 |8859 |ISO 646da |646da | Danish | +--------------+--------+--------------+--------+--------------------+ |ISO 8859-1 |8859 |ISO 646en |646en | English ASCII | +--------------+--------+--------------+--------+--------------------+ |ISO 8859-1 |8859 |ISO 646es |646es | Spanish | +--------------+--------+--------------+--------+--------------------+ |ISO 8859-1 |8859 |ISO 646fr |646fr | French | +--------------+--------+--------------+--------+--------------------+ |ISO 8859-1 |8859 |ISO 646it |646it | Italian | +--------------+--------+--------------+--------+--------------------+ |ISO 8859-1 |8859 |ISO 646sv |646sv | Swedish | +--------------+--------+--------------+--------+--------------------+ CONVERSIONS
The conversions are performed according to the following tables. All values in the tables are given in octal. ISO 8859-1 to ISO 646 (7-bit ASCII) For the conversion of ISO 8859-1 to ISO 646, all characters not in the following table are mapped unchanged. Converted to Underscore '_' (137) --------------------------------- 200 201 202 203 204 205 206 207 210 211 212 213 214 215 216 217 220 221 222 223 224 225 226 227 230 231 232 233 234 235 236 237 240 241 242 243 244 245 246 247 250 251 252 253 254 255 256 257 260 261 262 263 264 265 266 267 270 271 272 273 274 275 276 277 300 301 302 303 304 305 306 307 310 311 312 313 314 315 316 317 320 321 322 323 324 325 326 327 330 331 332 333 334 335 336 337 340 341 342 343 344 345 346 347 350 351 352 353 354 355 356 357 360 361 362 363 364 365 366 367 370 371 372 373 374 375 376 377 ISO 8859-1 to ISO 646de (GERMAN) For the conversion of ISO 8859-1 to ISO 646de, all characters not in the following tables are mapped unchanged. +-----------------------------------------------------------------+ | | Conversions|Performed | | | ISO 8859-1 | ISO 646de | ISO 8859-1 | ISO 646de | |247 | 100 |337 |176 | |304 | 133 |344 |173 | |326 | 134 |366 |174 | |334 | 135 |374 |175 | +---------------+----------------+----------------+---------------+ Converted to Underscore '_' (137) --------------------------------- 100 133 134 135 173 174 175 176 200 201 202 203 204 205 206 207 210 211 212 213 214 215 216 217 220 221 222 223 224 225 226 227 230 231 232 233 234 235 236 237 240 241 242 243 244 245 246 250 251 252 253 254 255 256 257 260 261 262 263 264 265 266 267 270 271 272 273 274 275 276 277 300 301 302 303 305 306 307 310 311 312 313 314 315 316 317 320 321 322 323 324 325 327 330 331 332 333 335 336 337 340 341 342 343 345 346 347 350 351 352 353 354 355 356 357 360 361 362 363 364 365 367 370 371 372 373 375 376 377 ISO 8859-1 to ISO 646da (DANISH) For the conversion of ISO 8859-1 to ISO 646da, all characters not in the following tables are mapped unchanged. +-----------------------------------------------------------------+ | Conversions Performed | +---------------+----------------+----------------+---------------+ | ISO 8859-1 | ISO 646da | ISO 8859-1 | ISO | +---------------+----------------+----------------+---------------+ |646da | | | | +---------------+----------------+----------------+---------------+ |305 | 135 |345 |175 | +---------------+----------------+----------------+---------------+ |306 | 133 |346 |173 | +---------------+----------------+----------------+---------------+ |330 | 134 |370 |174 | +---------------+----------------+----------------+---------------+ Converted to Underscore '_' (137) --------------------------------- 133 134 135 173 174 175 200 201 202 203 204 205 206 207 210 211 212 213 214 215 216 217 220 221 222 223 224 225 226 227 230 231 232 233 234 235 236 237 240 241 242 243 244 245 246 247 250 251 252 253 254 255 256 257 260 261 262 263 264 265 266 267 270 271 272 273 274 275 276 277 300 301 302 303 304 307 310 311 312 313 314 315 316 317 320 321 322 323 324 325 326 327 331 332 333 334 335 336 337 340 341 342 343 344 347 350 351 352 353 354 355 356 357 360 361 362 363 364 365 366 367 371 372 373 374 376 377 ISO 8859-1 to ISO 646en (ENGLISH ASCII) For the conversion of ISO 8859-1 to ISO 646en, all characters not in the following tables are mapped unchanged. +-----------------------------------------------------------+ | Conversions Performed | +-----------------------------+-----------------------------+ | ISO 8859-1 | ISO 646en | +-----------------------------+-----------------------------+ |243 |043 | +-----------------------------+-----------------------------+ Converted to Underscore '_' (137) --------------------------------- 043 200 201 202 203 204 205 206 207 210 211 212 213 214 215 216 217 220 221 222 223 224 225 226 227 230 231 232 233 234 235 236 237 240 241 242 244 245 246 247 250 251 252 253 254 255 256 257 260 261 262 263 264 265 266 267 270 271 272 273 274 275 276 277 300 301 302 303 304 305 306 307 310 311 312 313 314 315 316 317 320 321 322 323 324 325 326 327 330 331 332 333 334 335 336 337 340 341 342 343 344 345 346 347 350 351 352 353 354 355 356 357 360 361 362 363 364 365 366 367 370 371 372 373 374 375 376 377 ISO 8859-1 to ISO 646fr (FRENCH) For the conversion of ISO 8859-1 to ISO 646fr, all characters not in the following tables are mapped unchanged. +-----------------------------------------------------------------+ | | Conversions|Performed | | | ISO 8859-1 | ISO 646fr | ISO 8859-1 | ISO 646fr | |243 | 043 |347 |134 | |247 | 135 |350 |175 | |250 | 176 |351 |173 | |260 | 133 |371 |174 | |340 | 100 | | | +---------------+----------------+----------------+---------------+ Converted to Underscore '_' (137) --------------------------------- 043 100 133 134 135 173 174 175 176 200 201 202 203 204 205 206 207 210 211 212 213 214 215 216 217 220 221 222 223 224 225 226 227 230 231 232 233 234 235 236 237 240 241 242 244 245 246 251 252 253 254 255 256 257 261 262 263 264 265 266 267 270 271 272 273 274 275 276 277 300 301 302 303 304 305 306 307 310 311 312 313 314 315 316 317 320 321 322 323 324 325 326 327 330 331 332 333 334 335 336 337 341 342 343 344 345 346 352 353 354 355 356 357 360 361 362 363 364 365 366 367 370 372 373 374 375 376 377 ISO 8859-1 to ISO 646it (ITALIAN) For the conversion of ISO 8859-1 to ISO 646it, all characters not in the following tables are mapped unchanged. +-----------------------------------------------------------------+ | | Conversions|Performed | | | ISO 8859-1 | ISO 646it | ISO 8859-1 | ISO 646it | |243 | 043 |350 |175 | |247 | 100 |351 |135 | |260 | 133 |354 |176 | |340 | 173 |362 |174 | |347 | 134 |371 |140 | +---------------+----------------+----------------+---------------+ Converted to Underscore '_' (137) --------------------------------- 043 100 133 134 135 173 174 175 176 200 201 202 203 204 205 206 207 210 211 212 213 214 215 216 217 220 221 222 223 224 225 226 227 230 231 232 233 234 235 236 237 240 241 242 244 245 246 250 251 252 253 254 255 256 257 261 262 263 264 265 266 267 270 271 272 273 274 275 276 277 300 301 302 303 304 305 306 307 310 311 312 313 314 315 316 317 320 321 322 323 324 325 326 327 330 331 332 333 334 335 336 337 341 342 343 344 345 346 352 353 354 355 356 357 360 361 362 363 364 365 366 367 370 372 373 374 375 376 377 ISO 8859-1 to ISO 646es (SPANISH) For the conversion of ISO 8859-1 to ISO 646es, all characters not in the following tables are mapped unchanged. +-----------------------------------------------------------------+ | | Conversions|Performed | | | ISO 8859-1 | ISO 646es | ISO 8859-1 | ISO 646es | |241 | 133 |321 |134 | |247 | 100 |347 |175 | |260 | 173 |361 |174 | |277 | 135 | | | +---------------+----------------+----------------+---------------+ Converted to Underscore '_' (137) --------------------------------- 100 133 134 135 173 174 175 200 201 202 203 204 205 206 207 210 211 212 213 214 215 216 217 220 221 222 223 224 225 226 227 230 231 232 233 234 235 236 237 240 242 243 244 245 246 250 251 252 253 254 255 256 257 261 262 263 264 265 266 267 270 271 272 273 274 275 276 300 301 302 303 304 305 306 307 310 311 312 313 314 315 316 317 320 322 323 324 325 326 327 330 331 332 333 334 335 336 337 340 341 342 343 344 345 346 350 351 352 353 354 355 356 357 360 362 363 364 365 366 367 370 371 372 373 374 375 376 377 ISO 8859-1 to ISO 646sv (SWEDISH) For the conversion of ISO 8859-1 to ISO 646sv, all characters not in the following tables are mapped unchanged. +-----------------------------------------------------------------+ | | Conversions|Performed | | | ISO 8859-1 | ISO 646sv | ISO 8859-1 | ISO 646sv | |304 | 133 |344 |173 | |305 | 135 |345 |175 | |311 | 100 |351 |140 | |326 | 134 |366 |174 | |334 | 136 |374 |176 | +---------------+----------------+----------------+---------------+ Converted to Underscore '_' (137) --------------------------------- 100 133 134 135 136 140 173 174 175 176 200 201 202 203 204 205 206 207 210 211 212 213 214 215 216 217 220 221 222 223 224 225 226 227 230 231 232 233 234 235 236 237 240 241 242 243 244 245 246 247 250 251 252 253 254 255 256 257 260 261 262 263 264 265 266 267 270 271 272 273 274 275 276 277 300 301 302 303 306 307 310 312 313 314 315 316 317 320 321 322 323 324 325 327 330 331 332 333 335 336 337 340 341 342 343 346 347 350 352 353 354 355 356 357 360 361 362 363 364 365 367 370 371 372 373 375 376 377 FILES
/usr/lib/iconv/*.so conversion modules /usr/lib/iconv/*.t conversion tables /usr/lib/iconv/iconv_data list of conversions supported by conversion tables SEE ALSO
iconv(1), iconv(3C), iconv(5) SunOS 5.10 28 Apr 1997 iconv_8859-1(5)
All times are GMT -4. The time now is 12:36 PM.
Unix & Linux Forums Content Copyright 1993-2022. All Rights Reserved.
Privacy Policy